java jsp el表达式报错_Java web:JSP实现登录界面,DBUtils,EL表达式,个人理解【诗书画唱】...

(自己写的题目)用JSP等的知识做出个登录界面(个人的理解:因为form表单中要用上action,所以可以取前3个字母的缩写act当用户名,账号名等)

bbb415bbe7be7bb0ed1606ae3afce9a5.png

92dbd9a10bc0c737bc4938e6e78e8944.png

f08a0745f467f226e636b67a58128cc6.png

create table user(

id int primary key auto_increment,

act varchar(100) ,

pwd varchar(100)

);

--drop table user

insert into user(act,pwd) values ("诗书画唱",'666'),("三连",'233'),("关注",'888' );

select *  from  user

51fceaf2a431f259584e1fcf1b8eed23.png

如果是手建的话,导出来有时看你自己的设计会为(红色部分比较有用,其他的没太多的用处):

/*

Navicat MySQL Data Transfer

Source Server         : mysql

Source Server Version : 50639

Source Host           : localhost:3306

Source Database       : j190802

Target Server Type    : MYSQL

Target Server Version : 50639

File Encoding         : 65001

Date: 2020-09-14 11:00:08

*/

SET FOREIGN_KEY_CHECKS=0;

-- ----------------------------

-- Table structure for `user`

-- ----------------------------

DROP TABLE IF EXISTS `user`;

CREATE TABLE `user` (

`id` int(11) NOT NULL AUTO_INCREMENT,

`act` varchar(30) DEFAULT NULL,

`pwd` varchar(30) DEFAULT NULL,

PRIMARY KEY (`id`)

) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8;

-- ----------------------------

-- Records of user

-- ----------------------------

INSERT INTO `user` VALUES ('1', 'admin2020', '123456');

731c04cffff340c1da02517693bc5378.png

但是我更喜欢用代码建表,就用我前面的建的表的内容:

3134b90ed4ce7497eaa164b07c693cf7.png

520ce87238e00f710340eccb330c1a26.png

3d98357112a59012ca114a343a69e065.png

package com.xhj.bean;

//bean的类名于表的名字一致,而且首字母必须大写

public class User {

//bean类中的属性名应该和表中的列名一致

private Integer id;

private String act;

private String pwd;

public Integer getId() {

return id;

}

public void setId(Integer id) {

this.id = id;

}

public String getAct() {

return act;

}

public void setAct(String act) {

this.act = act;

}

public String getPwd() {

return pwd;

}

public void setPwd(String pwd) {

this.pwd = pwd;

}

}

1984584ba4a3a2c8c0099aa3ec4940c9.png

3f0e9932bbebd926d4965a174dbe989d.png

package com.xhj.DAO;

import java.sql.Connection;

import java.sql.PreparedStatement;

import java.sql.ResultSet;

import java.sql.SQLException;

import com.xhj.Utils.DBUtils;

import com.xhj.bean.User;

//Dao是数据访问的意思,

//在这个类中负责对user表进行增删改查的功能实现

//Dao类中的方法就是负责执行sql语句,

//只要有执行sql语句的代码都必须写在dao类中

public class UserDao {

public User selectByActAndPwd

(String act,String pwd){

String sql = "select * "

+ "from User where act = ? and pwd = ?";

Connection conn = null;

PreparedStatement pstm = null;

ResultSet rs = null;

User u = new User();

try {

conn = DBUtils.getConn();

pstm = conn.prepareStatement(sql);

//设置占位符

pstm.setString(1, act);

pstm.setString(2, pwd);

rs = pstm.executeQuery();

if(rs.next()) {

Integer id = rs.getInt("id");

u.setId(id);

u.setAct(act);

u.setPwd(pwd);

}

} catch (SQLException e) {

// TODO Auto-generated catch block

e.printStackTrace();

} finally {

//清理资源

DBUtils.close(rs, pstm, conn);

}

return u;

}

public static void main(String[] args) {

UserDao ud = new UserDao();

User u = ud.selectByActAndPwd("诗书画唱", "666");

if(u.getId() != null && u.getId() > 0) {

System.out.println("登录成功");

} else {

System.out.println("登录失败");

}

}

}

39b18acf6606185d08391c4920b1d313.png

0976a078bdbbc2d86686772f2703de89.png

package com.xhj.Utils;

import java.io.IOException;

import java.io.InputStream;

import java.sql.Connection;

import java.sql.DriverManager;

import java.sql.PreparedStatement;

import java.sql.ResultSet;

import java.util.Properties;

public class DBUtils {

private static String driverName;

private static String url;

private static String user;

private static String pwd;

static {

//读取properties文件

Properties prop = new Properties();

//将db.properties文件读取到内存中去

InputStream is = DBUtils.class.getClassLoader()

.getResourceAsStream("db.properties");

//加载内容

try {

prop.load(is);

//读取内容

driverName = prop.getProperty("dn");

//System.out.println(driverName);

url = prop.getProperty("url");

user = prop.getProperty("un");

pwd = prop.getProperty("up");

} catch (IOException e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

}

//获取数据库连接对象的方法

public static Connection getConn(){

Connection conn = null;

try {

Class.forName(driverName);

conn = DriverManager.getConnection(url,user,pwd);

} catch (Exception e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

return conn;

}

public static void close(ResultSet rs,

PreparedStatement pstm

,Connection conn){

try {

if(rs != null) {

rs.close();

}

if(pstm != null) {

pstm.close();

}

if(conn != null) {

conn.close();

}

} catch(Exception e) {

e.printStackTrace();

}

}

}

c90733aefb239fbcd709709333f9208b.png

9d52db9958fbb15ec8e1aaa76f965047.png

dn=com.mysql.jdbc.Driver

url=jdbc:mysql://localhost:3306/firstjsp?useUnicode=true&characterEncoding=UTF-8

un=root

up=rootea3b14314ba0467a74846e17f5cc7ed8.png

42b69d4df7e7f8525f163a13cd24ba45.png

charset=UTF-8" pageEncoding="UTF-8"%>

String path = request.getContextPath();

String basePath = request.getScheme()

+"://"+request.getServerName()

+":"+request.getServerPort()+path+"/";

%>

/p>

Transitional//EN">

content="no-cache">

="keyword1,keyword2,keyword3">

="This is my page">

*{

font-size:50px;

}

,action中的内容的大小不可以写错不然会报错等

--%>

账号:

placeholder="请输入账号"/>

密码:

name="pwd" />

value="提交" />

${msg }

8243ca557f7c39d7334fae401c7ef24c.png

46221f26fc82d7b14d4bc7d5717a0935.png

charset=UTF-8" pageEncoding="UTF-8"%>

//中文乱码处理:

request.setCharacterEncoding("utf-8");

//1、获取用户输入的账号和密码:

String act = request.getParameter("act");

String pwd = request.getParameter("pwd");

System.out.println(act);

//2、查询数据库:

UserDao userDao = new UserDao();

User u = userDao.selectByActAndPwd(act, pwd);

//3、根据查询出来的结果进行处理

if(u.getId() != null && u.getId() > 0) {

//将登录的账号存放到session

//后面当你跳转到任何的页面时,

//还需要验证是否是合法的访问

request.getSession().setAttribute

("userName", act);

//a、根据账号和密码能够查询记录,就表示登录成功,

//跳转到后台管理页面

request.getRequestDispatcher

("manage.jsp").forward(request, response);

} else {

String msg = "账号或者密码错误";

request.setAttribute("msg", msg);

//b、没有查询到记录,就表示登录失败,跳转回login.jsp

request.getRequestDispatcher("login.jsp")

.forward(request, response);

}

%>

99b284c933edb0e2ea15c2df9efe3149.png

1a6a897db555fe6343ad1402588a9655.png

"text/html; charset=UTF-8" pageEncoding="UTF-8"%>

String path = request.getContextPath();

String basePath = request.getScheme()

+"://"+request.getServerName()

+":"+request.getServerPort()+path+"/";

%>

/p>

4.01 Transitional//EN">

content="no-cache">

content="keyword1,keyword2,keyword3">

content="This is my page">

欢迎登录本系统,${userName }

d78dcf1e062a3f55e1dd78f8bd8fed8e.png

f24113cf365915344f3e72b4f1b18280.png

e5bd84406e32a7f0063635ab22a6d5ff.png

9757ebb09f0eb32c13fb6720f8863e7c.png

f93dcaf7138ff4a0c18ab88a0888ba2f.png

68a7dc55dd3afba773dfb6c745eece30.png

267f39b2e58f78ed25926b157ace88b4.png

3eccb07b0ab5472f47c711295dfdf3fb.png

f6df3ffd6becdfa0b0b1f5a3f4c79914.png

eff5db82f781d6aeb8747ce76bb03eea.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值