先把实验 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
1自动在 LoginCheckServlet 页面生成的 @WebServlet("/CheckServlet")
2在 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>
来源: http://www.bubuko.com/infodetail-3078174.html