先把实验3的jsp页面复制过来;
WebContent->WEB-INF->lib下面的jar包8.0版本也要记得复制;
Java Resources->src下的 cn.edu.henu.bean(User.java 用户数据库操作)和cn.edu.henu.util(DBConnection.java 数据库的连接操作)这两个包
<?xml version="1.0" encoding="UTF-8"?> <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" id="WebApp_ID" version="3.0"> <display-name>ws_shiyan3</display-name> <welcome-file-list> <welcome-file>index.html</welcome-file> <welcome-file>index.htm</welcome-file> <welcome-file>addUser.jsp</welcome-file>
使用Servlet技术改写用户登录
src -> 新创建一个package “cn.edu.henu.servlet” ->新建一个servlet类名 “LoginCheckServlet” ->URL mapping设置为"/CheckServlet"
改写dopost()方法,把实验三 check.jsp的登陆验证代码复制过来即可
String name=request.getParameter("name"); String pwd=request.getParameter("pwd"); PreparedStatement pt=null; Connection con = null; User user = null; try { //JDBC访问数据库 con=DBConnection.openConnection();//获取数据库连接 String sql="SELECT * from login WHERE user=? AND passwod=?"; pt=con.prepareStatement(sql); pt.setString(1, name); pt.setString(2, pwd); ResultSet rs=pt.executeQuery(); System.out.println("?????????????????????"); if(rs.next()) { response.sendRedirect("connsuccess.jsp"); } else{ response.sendRedirect("connError.jsp"); } } catch (SQLException e) { e.printStackTrace();}
大家也可以参考这个 JSP+Servlet 的用户登录
【注意】这里User user = null; 下面黄色报警 所以我刚开始注释掉了,结果CheckServlet页面就404, 后来取消注释才可以
有两种方法配置Servlet
①自动在LoginCheckServlet页面生成的@WebServlet("/CheckServlet")
②在web.xml下面配置
<servlet> <servlet-name>LoginCheckServlet</servlet-name>//使用类名创建一个对象 <servlet-class>cn.edu.henu.servlet.LoginCheckServlet</servlet-class>//自己创建的servlet类 </servlet> <servlet-mapping> <servlet-name>LoginCheckServlet</servlet-name>//实际执行的对象 <url-pattern>/CheckServlet</url-pattern>//自定义的URL Mapping </servlet-mapping>
注意】这里名字要匹配哦
【注意】两个方法只能选一个配置,否则会报错
使用Filter技术解决中文乱码
src -> new Filter ( package的名字是" cn.edu.henu.Filter " , Filter名字是 “EncodingFilter” , MAP的名字我没有改 EncodingFilter
接着在doFilter()下输入 request.setCharacterEncoding(“utf-8”); 即可
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { // TODO Auto-generated method stub // place your code here request.setCharacterEncoding("utf-8"); // pass the request along the filter chain chain.doFilter(request, response); }
<filter> <filter-name>EncodingFilter</filter-name> <filter-class>cn.edu.henu.filter.EncodingFilter</filter-class> </filter> <filter-mapping> <filter-name>EncodingFilter</filter-name> <url-pattern>/*</url-pattern> //拦截所有请求 </filter-mapping>
原文:https://blog.csdn.net/wwjlovecyndi/article/details/90300255