java web 用户表_Java Web登录页面,重要题和自己想出的代码,用户表和用户类型表,导航栏【诗书画唱】...

3、创建一个用户表user和用户类型表userType(项目中的角色和权限问题)

user:id,act,pwd,tid

userType:tid,tname

创建登录页面login.jsp,登录成功后将act和tid保存在session中

登录成功后跳转到manage.jsp页面,页面中有一个导航栏,有如下选项:

管理所有用户

个人中心

购物车

要求当用户类型是超级管理员时,能够显示出导航栏中的所有选项

当用户类型是其他时,只显示个人中心和购物车179a1db39d10345ddb3728923c7800dc.png

create table user(

id int primary key auto_increment,

act varchar(100) ,

pwd varchar(100) ,

tid int

);

create table userType(

tid int primary key auto_increment,

tname varchar(100)

);

insert into User(act ,pwd ,tid ) values ("诗书画唱1","666",1),

("诗书画唱2","888",2);

insert into userType(tname) values ("超级管理员"),("其他");

--drop table  User

--select *  from User

--select *  from userType

select * from User inner  join  userType on User.tid= userType.tid

63c4a7d7a7779cf8e61ea71a1c323ba3.png

9cfbca7991af8598a2ceef1cee98b703.png

d061764b0fe5c70a6b924167c892cc96.png

e9961b6d3d129362de97d6d9c701e5ec.png

package bean;

public class User {

private Integer id;

private String act;

private String pwd;

private Integer tid;

private String tname;

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;

}

public Integer getTid() {

return tid;

}

public void setTid(Integer tid) {

this.tid = tid;

}

public String getTname() {

return tname;

}

public void setTname(String tname) {

this.tname = tname;

}

}

30a613fcba2ebc91ba552222ac997c4d.png

2ec9c1f5da763ee9d21ec4224c885761.png

package controller;

import bean.User;

import DAO.Dao;

import java.io.IOException;

import java.util.List;

import javax.servlet.ServletException;

import javax.servlet.annotation.WebServlet;

import javax.servlet.http.HttpServlet;

import javax.servlet.http.HttpServletRequest;

import javax.servlet.http.HttpServletResponse;

import bean.User;

import DAO.Dao;

@WebServlet("/UFirstPageServletStart")

public class FirstPageServletStart extends HttpServlet {

private static final long serialVersionUID = 1L;

public FirstPageServletStart() {

super();

// TODO Auto-generated constructor stub

}

/**

* @see HttpServlet#doGet(HttpServletRequest request,

*  HttpServletResponse response)

*/

protected void doGet(HttpServletRequest request,

HttpServletResponse response)

throws ServletException, IOException {

// TODO Auto-generated method stub

this.doPost(request, response);

}

protected void doPost(HttpServletRequest request,

HttpServletResponse response)

throws ServletException, IOException {

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

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

System.out.println(act);

//2、查询数据库

Dao userDao = new Dao();

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

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

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

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

//后面当你跳转到任何的页面时,还需要验证是否是合法的访问

request.getSession().setAttribute("userName", act);

//a、根据账号和密码能够查询记录,就表示登录成功,跳转到后台管理页面

StringBuilder html = new StringBuilder();

if("超级管理员".equals(u.getTname())){

html.append("

");

}

else if("其他".equals(u.getTname())){

html.append("

+ "

购物车");

}

System.out.println(html);

request.setAttribute("html",html);

request.getRequestDispatcher("firstPage.jsp").forward(request, response);

} else {

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

request.setAttribute("msg", msg);

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

request.getRequestDispatcher("login.jsp")

.forward(request, response);

}

}

}

f58844315877331ebaf0cc582decad1c.png

0544b7f7c981b5ac2e8a3a70ac41b0e8.png

2d9c43d1627c6a02659ea96da1ef7cfd.png

6c73dc9e6c4c736ded6c078a19830f49.png

package DAO;

import java.sql.Connection;

import java.sql.PreparedStatement;

import java.sql.ResultSet;

import java.sql.SQLException;

import java.util.ArrayList;

import java.util.List;

import utils.DBUtils;

import bean.User;

public class Dao {

public User selectByActAndPwd

(String act,String pwd){

String sql = "select * from user  u inner"

+ " join userType  ut on  u.tid=ut.tid"

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

Connection conn = null;

PreparedStatement pstm = null;

ResultSet rs = null;

User u = new User();

Listlist = new ArrayList();

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");

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

String tname= rs.getString("tname");

u.setId(id);

u.setAct(act);

u.setPwd(pwd);

u.setTid(tid);

u.setTname(tname);

}

} catch (SQLException e) {

// TODO Auto-generated catch block

e.printStackTrace();

} finally {

//清理资源

DBUtils.close(rs, pstm, conn);

}

return u;

}

}

397fb344fdb74583dc7b35bdc5f386d9.png

7802b4a732335d356fa3f9919915ab1b.png

package Filter;

import java.io.IOException;

import javax.servlet.Filter;

import javax.servlet.FilterChain;

import javax.servlet.FilterConfig;

import javax.servlet.ServletException;

import javax.servlet.ServletRequest;

import javax.servlet.ServletResponse;

import javax.servlet.annotation.WebFilter;

@WebFilter("/*")

public class CodeFilter implements Filter {

public CodeFilter() {

// TODO Auto-generated constructor stub

}

public void destroy() {

// TODO Auto-generated method stub

}

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");

chain.doFilter(request, response);

}

public void init(FilterConfig fConfig) throws ServletException {

// TODO Auto-generated method stub

}

}05b8ac68d2c956d1ff55f1e60ced8fcf.png

ed7fee28cd6ed757903531098de44956.png

package 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 userName;

private static String pwd;

//静态块,随着类加载而运行的

static{

//读取db.properties文件中的内容:

Properties prop = new Properties();

InputStream is = DBUtils.class.getClassLoader()

.getResourceAsStream("db.properties");

try {

prop.load(is);

driverName = prop.getProperty("dn");

url = prop.getProperty("url");

userName = 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,userName,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();

}

}

}

bc14a29f087ca9dc97fe6a71fbef661a.png

ec7ff3ae31c4b00c0b1f263bf1891acb.png

dn=com.mysql.jdbc.Driver

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

un=root

up=root7dbd23bafc324f5ee5bc5cd1fe6ee71b.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、查询数据库

Dao userDao = new Dao();

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

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

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

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

//后面当你跳转到任何的页面时,还需要验证是否是合法的访问

request.getSession().setAttribute("userName", act);

//a、根据账号和密码能够查询记录,就表示登录成功,跳转到后台管理页面

request.getRequestDispatcher("firstPage.jsp")

.forward(request, response);

} else {

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

request.setAttribute("msg", msg);

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

request.getRequestDispatcher("login.jsp")

.forward(request, response);

}

%>59b81ef064892ffb1f12c1a946ff2e81.png

f04c768a0c9ca028856e2c8b6cb4319e.png

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

String path = request.getContextPath();

String basePath = request.getScheme()

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

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

%>

"keyword1,keyword2,keyword3">

ul

{

list-style-type:none;

margin:0;

padding:0;

overflow:hidden;

background-color:black;

}

li

{

float:left;

padding:50px;

}

a

{

display:block;

text-decoration: none;

}

${html }

d39e2497d549fc48a9f21b5ecec6bec2.png

4025c093d461f68c8adfe9c1fbf96f79.png

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

String path = request.getContextPath();

String basePath = request.getScheme()+

"://"+request.getServerName()

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

%>

*{

font-size:50px;

}

账号:

placeholder="请输入账号"/>

密码:
${msg }

9bab9d6aa2f9be3d5bf287615e3e83ff.png

4f64e4e8394fa462a2ceb08bc66dbcfc.png

014e91ff08811a978e41361eb4f9522d.png

088003738f1b13db518df6c4082a054b.png

f1ad3c8ae358c6d130fc4d200b58b3a6.png

0711fc6b4af96315a91b087923dedd2b.png

43f86de2d19e7b81062356034559c95d.png

feec022ac6c69190d1b2f11346b1292e.png

259a09a26723a19d5394691d6208a48d.png

64243fd020d22162535681aa725be7e8.png

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值