木舟0基础学习Java的第二十六天(JavaWeb)

2024-09-06 18:44

本文主要是介绍木舟0基础学习Java的第二十六天(JavaWeb),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

设置响应头

resp.setHeader("key","nihao");//推荐使用英文 中文会乱码

案例:模拟登录

 jdbc.properties

driverClass=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/test?verifyServerCertificate=false&useSSL=false
name=root
password=123456

JDBCUtil

public class JDBCUtil {static String driverClass=null;static String url=null;static String name=null;static String password=null;static{Properties properties=new Properties();InputStream is=null;try {is=JDBCUtil.class.getClassLoader().getResourceAsStream("jdbc.properties");properties.load(is);driverClass=properties.getProperty("driverClass");url=properties.getProperty("url");name=properties.getProperty("name");password=properties.getProperty("password");} catch (IOException e) {throw new RuntimeException(e);}}public static Connection getConn(){Connection conn=null;try {Class.forName(driverClass);conn= DriverManager.getConnection(url,name,password);} catch (Exception e) {throw new RuntimeException(e);}return conn;}private static void closeConn(Connection conn){if(conn!=null){try {conn.close();} catch (SQLException e) {throw new RuntimeException(e);}finally{conn=null;}}}private static void closePs(PreparedStatement ps){if(ps!=null){try {ps.close();} catch (SQLException e) {throw new RuntimeException(e);}finally{ps=null;}}}private static void closeRs(ResultSet rs){if(rs!=null){try {rs.close();} catch (SQLException e) {throw new RuntimeException(e);}finally{rs=null;}}}public static void release(Connection conn,PreparedStatement ps,ResultSet rs){closeRs(rs);closePs(ps);closeConn(conn);}public static void release(Connection conn,PreparedStatement ps){closePs(ps);closeConn(conn);}
}

T_user

需要实现序列化 Serializable接口

public class T_user implements Serializable{private int id;private String name;private String pwd;public int getId() {return id;}public void setId(int id) {this.id = id;}public String getName() {return name;}public void setName(String name) {this.name = name;}public String getPwd() {return pwd;}public void setPwd(String pwd) {this.pwd = pwd;}@Overridepublic String toString() {return "T_user{" +"id=" + id +", name='" + name + '\'' +", pwd='" + pwd + '\'' +'}';}
}

UserDao

public interface UserDao {public T_user login(String uname, String pwd);
}

UserDaoImpl

public class UserDaoImpl implements UserDao {//处理数据连接数据库Connection conn=null;PreparedStatement ps=null;ResultSet rs=null;T_user user=null;@Overridepublic T_user login(String uname, String pwd) {try {conn= JDBCUtil.getConn();String sql="select * from t_user where uname=? and pwd=?";ps=conn.prepareStatement(sql);ps.setString(1,uname);ps.setString(2,pwd);rs=ps.executeQuery();while(rs.next()){String uname1 = rs.getString("uname");String pwd1 = rs.getString("pwd");user=new T_user();user.setName(uname1);user.setPwd(pwd1);}} catch (SQLException e) {throw new RuntimeException(e);}finally{JDBCUtil.release(conn,ps,rs);}return user;}
}

LoginService

@WebServlet("/LoginService")
public class LoginService extends HttpServlet {private UserDao UserDao;public LoginService() {UserDao=new UserDaoImpl();}@Overrideprotected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {req.setCharacterEncoding("utf-8");resp.setContentType("text/html;charset=utf-8");String uname = req.getParameter("uname");String pwd = req.getParameter("pwd");System.out.println("uname:" + uname + "\tpwd:" + pwd);T_user user=UserDao.login(uname,pwd);if(user!=null){resp.getWriter().write("<font color='red' size=30>登录成功,欢迎"+user.getName()+"回来!</font>");}else{resp.getWriter().write("<font color='red' size=30>登录失败,账号或密码错误!</font>");}}
}

login.html

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Title</title>
</head>
<body>
<form action="LoginService" method="post">用户名:<input type="text" name="uname">密码:<input type="password" name="pwd">爱好:<input type="checkbox" name="hobby" value="抽烟">抽烟<input type="checkbox" name="hobby" value="喝酒">喝酒<input type="checkbox" name="hobby" value="烫头">烫头<input type="checkbox" name="hobby" value="蹦迪">蹦迪<input type="submit" value="提交">
</form>
</body>
</html>

请求转发重定向

请求转发

特点:路径不会发生改变

缺点:每次刷新页面 就相当于重新提交

请求转发 在登录场景 和 转账场景不能使用
req.getRequestDispatcher("success.html").forward(req,resp);

重定向

缺点:不能携带数据

 resp.sendRedirect("success.html");

servlet跳转servlet

//将数据以键值对的方式存入req.setAttribute("user", user);//key,valuereq.getRequestDispatcher("HanderServlet").forward(req, resp);
@WebServlet("/HanderServlet")
public class HanderServlet extends HttpServlet {@Overrideprotected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {T_user user = (T_user)req.getAttribute("user");//利用getAttribute获取值resp.getWriter().write("<h1>系统提示</h1>");resp.getWriter().write("<hr/>");resp.getWriter().write("<font color='red'>欢迎,"+user.getUname()+"登录成功!</font>");}
}

Cookie

cookie技术是浏览器端的数据存储技术 解决了同一个工程下不同请求需要使用相同数据的问题 我们把请求需要共享的请求数据 存储在浏览器端 避免用户进行重复书写请求数据 

特点:适合少量数据 键值对 不安全

注意:一个cookie对象存储一条数据 多条数据 可以创建多个cookie对象进行存储

作用:Cookie技术解决不同请求发送之间的数据共享问题

Cookie的使用

@WebServlet("/LoginSerlet")
public class LoginUser extends HttpServlet {private com.dao.UserDao UserDao;public LoginUser() {UserDao = new UserDaoImpl();}@Overrideprotected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {req.setCharacterEncoding("UTF-8");resp.setContentType("text/html;charset=UTF-8");String uname = req.getParameter("uname");String pwd = req.getParameter("pwd");System.out.println("uname:" + uname + "\tpwd:" + pwd);T_user user=UserDao.login(uname,pwd);if(user!=null){//将数据存储到Cookie当中Cookie c1=new Cookie("name",user.getUname());Cookie c2=new Cookie("pwd",user.getPwd());//设置三天免登录 默认不设置时间 关闭浏览器立即失效c1.setMaxAge(24*3600*3);//把存储了登录信息的Cookie 通过响应resp 响应到浏览器中resp.addCookie(c1);resp.addCookie(c2);resp.sendRedirect("success");}else{req.getRequestDispatcher("login.html").forward(req, resp);}}
}
@WebServlet("/success")
public class LoginServlet extends HttpServlet {@Overrideprotected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {req.setCharacterEncoding("UTF-8");resp.setContentType("text/html;charset=UTF-8");//通过浏览器携带的cookie name=admin pwd=123456 找tomcat中cookie对象的数据//获取cookieCookie[] cookies = req.getCookies();//键值对String value=null;//遍历所有cookie 找cookie的key是user的cookie对象for (Cookie c : cookies) {if("name".equals(c.getName())) {value = c.getValue();System.out.println("name:"+value);}if("pwd".equals(c.getName())) {value = c.getValue();System.out.println("pwd:"+value);}}resp.getWriter().write("<h1>系统提示</h1>");resp.getWriter().write("<hr/>");resp.getWriter().write("<font color='red'>欢迎,"+value+"登录成功!</font>");}
}

中央仓库(jar包下载)

Maven Repository: Central (mvnrepository.com)icon-default.png?t=O83Ahttps://mvnrepository.com/repos/central

 Session

首先创建Session Session在tomcat容器中 有且只有一个

Session默认时间30分钟 在开发中一般都使用Session存储用户登录信息

@WebServlet("/SessionLogin")
public class SessionLogin extends HttpServlet {UserService service;public SessionLogin() {service = new UserServiceImpl();}@Overrideprotected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {req.setCharacterEncoding("UTF-8");resp.setContentType("text/html;charset=UTF-8");String uname = req.getParameter("uname");String pwd = req.getParameter("pwd");T_stu stu = service.login(uname, pwd);if(stu!=null){//创建sessionHttpSession session = req.getSession();//将数据以键值对的方式存入session.setAttribute("stu", stu);resp.sendRedirect("SessionUser");}else{req.getRequestDispatcher("login.html").forward(req, resp);}}
}
@WebServlet("/SessionUser")
public class SessionUser extends HttpServlet {@Overrideprotected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {req.setCharacterEncoding("UTF-8");resp.setContentType("text/html;charset=UTF-8");//创建sessionHttpSession session = req.getSession();//获取数据T_stu stu =(T_stu)session.getAttribute("stu");resp.getWriter().write("<h1>系统提示</h1>");resp.getWriter().write("<hr/>");resp.getWriter().write("<h1>登录成功,欢迎"+stu.getUname()+"登录!</h1>");resp.getWriter().write("<a href='exit'>退出</a>");}
}
@WebServlet("/exit")
public class SessionExit extends HttpServlet {@Overrideprotected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {req.setCharacterEncoding("UTF-8");resp.setContentType("text/html;charset=UTF-8");HttpSession session = req.getSession();//关闭sessionsession.invalidate();resp.sendRedirect("login.html");}
}

ServletContext(上下文对象携带数据)

生命周期 程序启动到结束

作用域 在项目内

创建

        //第一种创建方式 有就创建 没有就获取ServletContext sc1= this.getServletContext();//第二种ServletContext sc2=req.getSession().getServletContext();//第三种ServletContext c3=this.getServletConfig().getServletContext();

得到

 ServletContext sc = this.getServletContext();String a =(String) sc.getAttribute("a");String b =(String) sc.getAttribute("b");String c =(String) sc.getAttribute("c");resp.getWriter().write("a:"+a+"b:"+b+"c:"+c);

删除

ServletContext sc = this.getServletContext();//删除bsc.removeAttribute("b");

读取配置文件的配置信息

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"version="4.0"><context-param><param-name>name</param-name><param-value>木舟</param-value></context-param>
</web-app>
String city = sc.getInitParameter("city");System.out.println(city);

这篇关于木舟0基础学习Java的第二十六天(JavaWeb)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1142816

相关文章

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06