javaWeb_评论管理&首页数据绑定&include指令

一、后台模糊查询

             1. 运行admin.jsp之后,默认显示所有新闻。

             2. 在输入框中输入关键词点击搜索  跳转到本页面                  

             3. 通过request内置对象获取当前模糊查询表单提交的关键词

             4. 将指定编码的字符串进行解码,通过getBytes("编码"),构造函数new String()编码

     

  <!-- 实现admin.jsp页面中模糊查询的搜索功能(根据标题进行模糊查询) -->
                <div style = "width:100%;height:40px;text-align: center;line-height:40px; ">
                    <form action = "admin.jsp" method = "post">
                        <label>新闻标题</label>
                        <!-- autocomplete 关闭自动提示 -->
                        <input type = "text" name = "strName" autocomplete="off"/>
                        <input type = "submit" value = "搜索"/>
                    </form>
                </div>
                
                <%
                    
                    //编码设置
                    request.setCharacterEncoding("utf-8");
                    String strName = request.getParameter("strName");
                    //搜索的关键词为中文  获取时会出现乱码    通过String类进行编码和解码
                    System.out.println("模糊查询的关键词为:[解决前] "+strName);
                    //sql语句
                    String sql = "select * from tb_news";
                    //第一次运行admin.jsp  strName为null  不能调用任何方法
                    if(null!=strName){
                        strName = new String(strName.getBytes("ISO-8859-1"),"utf-8");
                
                        sql+=" where ntitle like '%"+strName+"%'";
                    }
                %>

二、 首页数据绑定

          1. 与数据库进行交互显示所有主题(进行数据绑定)

          2. 为通过点击相应主题出现相应文章

          3. 显示新闻

<%@page import="java.sql.ResultSet"%>
<%@page import="java.sql.PreparedStatement"%>
<%@page import="java.sql.DriverManager"%>
<%@page import="java.sql.Connection"%>
<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>新闻首页</title>
        <link rel="stylesheet" type="text/css" href="admin/css/main.css" />
    </head>
    <body>
        <div id="container">
            <div class="sidebar">
                <h1> <img src="admin/images/title_1.gif" alt="国内新闻" /> </h1>
                <div class="side_list">
 
                </div>
                <h1> <img src="admin/images/title_2.gif" alt="国际新闻" /> </h1>
                <div class="side_list">
 
                </div>
                <h1> <img src="admin/images/title_3.gif" alt="娱乐新闻" /> </h1>
        
            </div>
            <div class="main">
                <div class="class_type"> <img src="admin/images/class_type.gif" alt="新闻中心" /> </div>
                <div class="content">
                
                    <!-- 3.index.jsp用户首页的新闻分类显示(数据绑定) -->
                    <ul class="class_date">
                        <li id='class_month'> 
                        <a href = "index.jsp"><b>&nbsp;全部&nbsp;</b></a>
                        <%
                        //加载驱动
                        Class.forName("oracle.jdbc.driver.OracleDriver");
                        //建立连接
                        String url = "jdbc:oracle:thin:@localhost:1521:orcl";
                        Connection conn = DriverManager.getConnection(url, "scott", "123");
                        //sql
                        String sql = "select * from tb_news_theme";
                        PreparedStatement ps = conn.prepareStatement(sql);
                        ResultSet rs = ps.executeQuery();
                        //sql  select count(*) from tb_news_theme
                        int count = 1;
                        while(rs.next()){
                            count++;
                            out.println("<a href='index.jsp?username="+username+"&ntid="+rs.getInt(1)+"'><b> "+rs.getString(2)+" </b></a> ");
                            //11 就是总记录数
                            if(count%11==0){
                                out.println("<br/>");
                            }
                        }
                        %>
                        </li>
                    </ul>
                    <!-- 当进入index.jsp页面后,手动点击对应的主题名称  跳转到本页面  获取当前点击的主题名称 -->
                    <%
                        username = request.getParameter("username");
                        String tid  = request.getParameter("ntid");
                        if(null!=tid){//说明点击了主题分类
                            //根据点击的主题分类进行查询  where 条件
                            sql = "select * from tb_news where ntid = "+Integer.valueOf(tid);
                        }else{//第一次进来,没有点击主题分类
                            sql = "select * from tb_news";//查询所有新闻
                        }
                    %>
                    
                    <!-- 新闻显示  start-->
                    <ul class="classlist">
                        <%
                            //sql
                            ps = conn.prepareStatement(sql);
                            rs = ps.executeQuery();
                            while(rs.next()){
                                out.println("<li><a href='newRead.jsp?username="+username+"&nid="+rs.getInt(1)+"'> "+rs.getString(3)+" </a><span> "+rs.getString(8)+" </span></li>");
                            }
                        
                        %>
                        
                    </ul>
                </div>
                <div class="picnews">
            
                </div>
            </div>
        </div>
        <div id="friend">
            <h1 class="friend_t"> <img src="admin/images/friend_ico.gif" alt="合作伙伴" /> </h1>
            <div class="friend_list">
    
            </div>
        </div>
    <!-- 通过jsp中的include指令进行引入第三方页面 -->
        <%@ include file="foot.jsp" %>
        
</html>

三、前端登录

               1. 登录布局

              2.,登录的js验证

              3. 数据库交互

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>新闻发布前台-用户登录</title>
<link type="text/css" rel="stylesheet" href="css/style.css" />
<!-- 修改成本地 -->
<script src="https://www.jq22.com/jquery/jquery-1.10.2.js"></script>
<script type="text/javascript">
$(document).ready(function () {
   var height=$(document).height();
   $('body').css('height',height);
   var mart=height-500;
   mart = mart/2;
   $('.loginBox').css('marginTop',mart);
})
</script>
</head>
 
<body>
<div class="loginBox">
  <h1>欢迎登陆</h1>
  <form action = "doLogin.jsp" method = "post">
      <div class="item">
        <div class="icon"><img src="images/icon1.png" /></div>
        <div class="txt"><input name="username" type="text" placeholder="请输入您的用户名"/></div>
      </div>
      <div class="item">
        <div class="icon"><img src="images/icon2.png" /></div>
        <div class="txt"><input name="password" type="password" placeholder="请输入您的密码"/></div>
      </div>
      <div class="item_2">
        <input name="" type="checkbox" value="" />
        <span>记住密码</span>
        <a href="psd.html">忘记密码?</a>
      </div>
      <div class="item_3">
        <input name="" type="submit" value="安全登录" class="btn"/>
      </div>
  </form>
  <div class="item_4">
    还没有账号?<a href="register.html">立即注册</a>
  </div>
</div>
</body>
</html>



四、评论管理 

          (1)显示评论以及增加评论

                  1. 先与数据库交互显示文章

                 2. 再与数据量交互显示评论

                  3.再布局增加评论

<%@page import="java.sql.ResultSet"%>
<%@page import="java.sql.PreparedStatement"%>
<%@page import="java.sql.DriverManager"%>
<%@page import="java.sql.Connection"%>
<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
    
    <!-- 获取 当前传递的参数用户以及新闻编号 -->
    <%
        //设置编码
        request.setCharacterEncoding("utf-8");
        String username = request.getParameter("username");//用户名    
    
    %>
    
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<link rel="stylesheet" type="text/css" href="admin/css/read.css" />
        <script type="text/javascript">
            function check() {
                var cauthor = document.getElementById("cauthor");
                var content = document.getElementById("ccontent");
                if (cauthor.value == "") {
                    alert("用户名不能为空!!");
                    return false;
                } else if (content.value == "") {
                    alert("评论内容不能为空!!");
                    return false;
                }
                return true;
            }
        </script>
    </head>
    <body>
        <div id="header">
 
        </div>
        <div id="container">
            <div class="sidebar">
                <h1> <img src="admin/images/title_1.gif" alt="国内新闻" /> </h1>
                <div class="side_list">
        
                </div>
                <h1> <img src="admin/images/title_2.gif" alt="国际新闻" /> </h1>
                <div class="side_list">
        
                </div>
                <h1> <img src="admin/images/title_3.gif" alt="娱乐新闻" /> </h1>
                <div class="side_list">
            
                </div>
            </div>
            <div class="main">
                <div class="class_type"> <img src="admin/images/class_type.gif" alt="新闻中心" /> </div>
                <div class="content">
                    <!-- 该区域实现新闻详情显示  start -->
                    
                    <%
                        //定义所谓变量(新闻标题,发布时间,点击量,新闻内容等等)
                        String ntitle = "";//标题
                        String ndate = "";//发布时间
                        String nauthor = "";//作者
                        String ncontent = "";//内容
                        int ncount = 0;//点击量
                    
                        
                        //2.获取id
                        String id = request.getParameter("nid");
                        //转换
                        int nid = 0;
                        if(null!=id){
                            nid = Integer.valueOf(id);
                        }
                        //3.获取数据
                        //加载驱动
                        Class.forName("oracle.jdbc.driver.OracleDriver");
                        //建立连接
                        Connection conn = DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:orcl", "scott","123");
                        //sql语句
                        String sql = "select * from tb_news where nid = ?";
                        //将sql语句传入方法返回执行对象
                        PreparedStatement ps = conn.prepareStatement(sql);
                        ps.setInt(1, nid);
                        //返回结果集对象
                        ResultSet rs = ps.executeQuery();
                        //if改造
                        if(rs.next()){
                            ntitle = rs.getString(3);
                            ndate = rs.getString(8);
                            nauthor = rs.getString(4);
                            ncontent = rs.getString(6);
                            ncount = rs.getInt(9);
                        }
                    %>
                
                
                
                    <ul class="classlist">
                        <table width="80%" align="center">
                            <tr width="100%">
                                <td colspan="2" align="center"><%=ntitle %>
                                &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
                                &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
                                &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
                                &nbsp;&nbsp;&nbsp; 点击量 <%=ncount %></td>
                            </tr>
                            <tr>
                                <td colspan="2">
                                    <hr />
                                </td>
                            </tr>
                            <tr>
                                <td align="center"><%=ndate %></td>
                                <td align="left"><%=nauthor %> </td>
                            </tr>
                            <tr>
                                <td colspan="2" align="center"></td>
                            </tr>
                            <tr>
                                <td colspan="2"> <%=ncontent %> </td>
                            </tr>
                            <tr>
                                <td colspan="2">
                                    <hr />
                                </td>
                            </tr>
                        </table>
                    </ul>
                    <ul class="classlist">
                        <table width="80%" align="center">
                            <!-- 从index.jsp页面中跳转到详情页面,如果有评论  此处要显示出来,如果没有
                            评论  显示 "暂无评论" 
                            -->
                            <%
                                //定义一个变量存储指定新闻的评论数
                                int commentCount = 0;
                                //1.求指定新闻的评论数判断
                                sql ="select count(*) from tb_comment where cnid = ?";
                                ps = conn.prepareStatement(sql);
                                ps.setInt(1, nid);
                                rs = ps.executeQuery();
                                if(rs.next()){
                                    commentCount = rs.getInt(1);
                                }
                                
                                if(commentCount!=0){
                                    //遍历所有的评论
                                    sql ="select * from tb_comment where cnid = ?";
                                    ps = conn.prepareStatement(sql);
                                    ps.setInt(1, nid);
                                    rs = ps.executeQuery();
                                    while(rs.next()){
                                        sql = "select * from tb_news_users where userid = ?";
                                        ps = conn.prepareStatement(sql);
                                        ps.setInt(1, rs.getInt(2));
                                        ResultSet rs2 = ps.executeQuery();
                                        String uname = "";
                                        if(rs2.next()){
                                            uname = rs2.getString(2);
                                        }
                                        
                                        out.println("<tr>");
                                        out.println("<td>");
                                        out.println("用户名:"+uname+"<br/>");
                                        
                                        out.println("评论内容:"+rs.getString(5));
                                        out.println("&nbsp;&nbsp;&nbsp;&nbsp;<a href = 'doDelComment.jsp?username="+username+"&cid="+rs.getInt(1)+"'>删除</a><br/>");
                                        out.println("评论时间:"+rs.getString(6)+"<br/>");
                                        out.println("</td>");
                                        out.println("</tr>");
                                        out.println("<tr>");
                                        out.println("<td>");
                                        out.println("&nbsp;");
                                        out.println("</td>");
                                        out.println("</tr>");
                                    }
                                    
                                    
                                }else{
                                    out.println("<td colspan='6'> 暂无评论! </td>");
                                }
                            
                            %>
                        
                            <tr>
                                <td colspan="6">
                                    <hr />
                                </td>
                            </tr>
                        </table>
                    </ul>
                    <ul class="classlist">
                        <form action="doComment.jsp" method="post" onsubmit="return check()">
                            <!-- 通过隐藏域标签传递新闻编号 -->
                            <input type = "hidden" name = "nid" value = "<%=nid %>"/>
                            
                            <table width="80%" align="center">
                                <tr>
                                    <td> 评 论 </td>
                                </tr>
                                <tr>
                                    <td> 用户名: </td>
                                    <td><input id="cauthor" name="username" value="<%=username %>" />
                                        IP:
                                        <input name="cip" value="127.0.0.1" readonly="readonly" />
                                    </td>
                                </tr>
                                <tr>
                                    <td colspan="2"><textarea name="ccontent" cols="70" rows="10"></textarea>
                                    </td>
                                </tr>
                                <td><input name="submit" value="发  表" type="submit" />
                                </td>
                            </table>
                        </form>
                    </ul>
                </div>
            </div>
        </div>
        <div id="friend">
            <h1 class="friend_t"> <img src="admin/images/friend_ico.gif" alt="合作伙伴" /> </h1>
            <div class="friend_list">
                
            </div>
        </div>
        <
    </body>
</html>

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: javaweb_cloud_elevue_pro微服务框架旗舰版源码是一套针对Java开发的微服务框架,该框架提供了一系列功能和组件,用于帮助开发者更轻松地构建和管理微服务架构。 该框架的源码是指该框架的具体实现代码,通过阅读源码,开发者可以深入了解框架的设计思想和实现细节,有助于更好地理解和使用该框架。 javaweb_cloud_elevue_pro微服务框架旗舰版源码的特点主要包括以下几点: 1. 模块化设计:源码采用模块化设计,将整个框架拆分成多个独立的模块,每个模块负责不同的功能,有利于代码的组织和维护。 2. 弹性扩展:框架采用了微服务架构,可以很方便地进行系统扩展,支持动态添加和移除服务实例,以适应不同的业务需求。 3. 高可用性:框架提供了集群和负载均衡的支持,可以提高系统的可用性和性能。 4. 分布式事务管理:源码包含了分布式事务管理的实现,可以保证系统在多节点环境下的数据一致性。 5. 可靠消息传递:框架提供了消息队列和分布式任务调度的功能,可以确保消息的可靠传递和任务的可靠执行。 6. 监控和管理:框架提供了丰富的监控和管理功能,可以对系统进行实时监控和管理,方便开发者进行故障排查和性能调优。 总之,javaweb_cloud_elevue_pro微服务框架旗舰版源码是一套成熟的微服务框架实现代码,通过研究源码,开发者可以更好地理解和使用该框架,提高开发效率和系统稳定性。 ### 回答2: javaweb_cloud_elevue_pro微服务框架是一款功能强大的微服务开发框架,是javaweb_cloud_elevue_pro产品家族中的旗舰版。 该框架的源码提供了一套完整的微服务解决方案,包含了丰富的功能模块和技术组件,可用于构建高性能、稳定可靠的分布式系统。 源码中包含了一系列核心组件,如服务注册与发现、负载均衡、熔断降级、分布式配置中心等,这些组件可以快速搭建起一个具有高可用性和可伸缩性的微服务架构。 此外,框架的源码还提供了一套易用的开发工具和开发规范,使开发者能够快速上手并高效地开发微服务应用。开发者可以根据自己的业务需求,选择合适的组件和模块进行使用,从而实现个性化的定制和扩展。 与其他微服务框架相比,javaweb_cloud_elevue_pro微服务框架的源码具有以下特点: 1. 高性能:框架使用了一系列优化的算法和技术,能够实现高效的请求处理和资源利用,保证系统的稳定和可靠。 2. 可扩展:源码提供了丰富的扩展接口和插件机制,开发者可以根据自己的需求进行个性化的扩展和定制。 3. 易用性:框架的源码结构清晰,文档详细,附带了示例和教程,使开发者能够快速理解和掌握框架的使用方法。 4. 社区支持:javaweb_cloud_elevue_pro框架拥有一个活跃的社区,开发者可以在社区中获取帮助、交流经验,并参与框架的改进和贡献。 总之,javaweb_cloud_elevue_pro微服务框架旗舰版源码提供了一个完整的微服务解决方案和一套易用的开发工具,可帮助开发者快速构建高性能、稳定可靠的分布式系统。它是微服务领域中的佼佼者,值得开发者深入研究和使用。 ### 回答3: javaweb_cloud_elevue_pro微服务框架旗舰版源码是一套用于构建微服务架构的开源代码。该框架旨在提供一种简单、高效的方式来搭建和管理分布式系统。 该框架基于Java语言,采用了云计算、分布式计算和微服务架构的设计理念,提供了一套完整的解决方案来构建和管理分布式应用。 该框架具有以下特点: 1. 架构灵活:框架提供了一套灵活的架构设计,可以根据业务需求进行扩展和定制。 2. 模块化设计:框架采用模块化设计,各个微服务模块之间可以独立部署和调用,实现了高内聚、低耦合的分布式系统。 3. 高可用性:框架支持负载均衡、容错和故障恢复等机制,保证了系统的高可用性和容错性。 4. 弹性扩展:框架支持水平扩展,可以根据需求动态增加或减少服务实例,实现了系统的弹性扩展和负载均衡。 5. 服务治理:框架提供了服务注册与发现、负载均衡、熔断器等功能,实现了对微服务的有效治理和管理。 6. 高性能:框架采用了高性能、高并发的设计和优化策略,提升了系统的性能和扩展能力。 总体而言,javaweb_cloud_elevue_pro微服务框架旗舰版源码是一套功能强大、灵活可扩展的微服务架构代码,可帮助开发人员快速构建和管理分布式系统。无论是在企业级应用程序还是在云计算环境中,该框架都能提供优秀的支持,并具有较高的性能和可靠性。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值