要求:
必备知识:JAVA/Struts2,JS/JQuery,HTML/CSS基础语法;
开发环境:MyEclipse 10

关于UI部分请查看下列链接,有详细制作步骤:

前段时间学校刚学完Struts2-Action篇,又自学了一点AJAX/JQuery,到网上看了一些CSS3知识。突然想要不要干脆做一个用户注册与登入功能。下面是JAVA部分的核心代码, 如果这样的逻辑和大家想的很有出入的话,欢迎拍砖劈斧,呵呵。

UserAction.java

package action;

import java.io.IOException;
import java.io.PrintWriter;
import java.util.LinkedList;
import org.apache.struts2.ServletActionContext;
import com.opensymphony.xwork2.ActionContext;
import com.opensymphony.xwork2.ActionSupport;
import dao.UserDao;
import entity.User; public class UserAction extends ActionSupport { private String contentType = "text/html;charset=utf-8";
private User user;
private LinkedList<User> users;
public LinkedList<User> getUsers() {
return users;
}
public void setUsers(LinkedList<User> users) {
this.users = users;
}
public User getUser() {
return user;
}
public void setUser(User user) {
this.user = user;
}
/**
* 查询用户 登入验证
* @return
* @throws IOException
*/
public void select() throws IOException{
//指定输出内容类型和编码
ServletActionContext.getResponse().setContentType(contentType);
//获取输出流,然后使用
PrintWriter out = null;
out = ServletActionContext.getResponse().getWriter();
this.user=new UserDao().select(user); //给this.user赋值
if(user==null){
out.print("登入失败");
}else{
ActionContext actionContext=ActionContext.getContext();
actionContext.getSession().put("user",user);
actionContext.getSession().put("users",new UserDao().getList());
out.print("登入成功");
}
out.flush();
out.close();
} /**
* 添加用户控制器
* @throws Exception
*/
public void add() throws IOException{
//指定输出内容类型和编码
ServletActionContext.getResponse().setContentType(contentType);
//获取输出流,然后使用
PrintWriter out = null;
out = ServletActionContext.getResponse().getWriter();
int rs=new UserDao().add(this.user);
if(rs==1){
ActionContext actionContext=ActionContext.getContext();
actionContext.getSession().put("user",user);
actionContext.getSession().put("users",new UserDao().getList()); }
out.print(rs);
out.flush();
out.close();
//System.out.print(new UserDao().add(this.user)); 这里不能在用 System.out.print() 否则后台报错 } public String upd(){ return null;
} public String del(){ return null;
} /*@Override
public String execute() throws Exception {
// TODO Auto-generated method stub
return super.execute();
}*/ }

  UserDao.java

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.LinkedList;
import java.util.List;
import tools.ConvertJson;
import tools.JDBCUtilSingle;
import entity.User;
public class UserDao { /**
* 插入操作 注册功能
* @param user 用户实例 POJO
* @return 操作标记 1成功 2邮箱存在 3用户名存在
*/
public int add(User user){
Connection connection=null;
PreparedStatement statement=null;
ResultSet rs=null;
connection=JDBCUtilSingle.getInitJDBCUtil().getConnection();
String sql="select * from form2_user where name=? or email=?";
try {
statement=connection.prepareStatement(sql);
statement.setString(1,user.getName());
statement.setString(2, user.getEmail());
rs=statement.executeQuery();
if(rs.next()){
if(rs.getString("email").equals(user.getEmail())){return 2;} //2邮箱存在
if(rs.getString("name").equals(user.getName())){return 3;} //3用户名存在
}
sql="INSERT INTO form2_user (`id`, `email`, `name`, `pass`) VALUES (NULL,?,?,?)";
statement=connection.prepareStatement(sql);
statement.setString(1,user.getEmail());
statement.setString(2,user.getName() );
statement.setString(3, user.getPass());
statement.executeUpdate();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} finally{
JDBCUtilSingle.getInitJDBCUtil().closeConnection(rs, statement, connection);
} return 1; //1表示成功注册
} /**
* 用户登录 放回登入用户对象信息
* @param user 用户对象
* @return
*/
public User select(User user){
Connection connection=null;
PreparedStatement statement=null;
ResultSet rs=null;
User myUser=null;
connection=JDBCUtilSingle.getInitJDBCUtil().getConnection();
String sql="select * from form2_user where (name=? or email=?) and pass=?";
try {
statement=connection.prepareStatement(sql);
statement.setString(1,user.getName());
statement.setString(2,user.getName());
statement.setString(3,user.getPass());
rs=statement.executeQuery();
if(rs.next()){
myUser=new User();
myUser.setName(rs.getString("name"));
myUser.setEmail(rs.getString("email"));
myUser.setPass(rs.getString("pass")); }
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}finally{
JDBCUtilSingle.getInitJDBCUtil().closeConnection(rs, statement, connection);
} return myUser;
} /**
* 获取所有用户信息
* @return 用户集合
*/
public LinkedList<User> getList(){
Connection connection=null;
PreparedStatement statement=null;
ResultSet rs=null;
User myUser=null;
LinkedList<User> users=new LinkedList<User>();
connection=JDBCUtilSingle.getInitJDBCUtil().getConnection();
String sql="select * from form2_user";
try {
statement=connection.prepareStatement(sql);
rs=statement.executeQuery();
while(rs.next()){
myUser=new User(rs.getString("email"),rs.getString("name"), rs.getString("pass"));
users.add(myUser);
}
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}finally{
JDBCUtilSingle.getInitJDBCUtil().closeConnection(rs, statement, connection);
} return users;
} }

  User.java

package entity;

public class User {
private String email;
private String name;
private String pass;
public String getEmail() {
return email;
}
public void setEmail(String email) {
this.email = email;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getPass() {
return pass;
}
public void setPass(String pass) {
this.pass = pass;
}
public User(){} public User(String email,String name, String pass){
this.email=email;
this.name=name;
this.pass=pass;
} }

  呵呵,又结束了,不知到你们看懂了没。请原谅童鞋我目前的表述能力只能到这了。欢迎大家来拍砖来劈斧,希望我幼小的心灵能抗得住。

作者:Li-Cheng

Struts2+AJAX+JQuery 实现用户登入与注册功能的更多相关文章

  1. Struts2+AJAX+JQuery 实现用户登入与注册功能。

    要求 必备知识 JAVA/Struts2,JS/JQuery,HTML/CSS基础语法. 开发环境 MyEclipse 10 演示地址 演示地址 预览截图(抬抬你的鼠标就可以看到演示地址哦): 关于U ...

  2. ssh整合问题总结--使用struts2+Ajax+jquery验证用户名是否已被注册

    在用户模块中的用户注册需求上,通常要进行用户名是否已被注册的验证,今天正好写了这个需求,把详细代码和所遇到的问题贴过来.在使用struts2+ajax时候,通常我们会返回json类型的数据,但是像上面 ...

  3. [Django]登陆界面以及用户登入登出权限

    前言:简单的登陆界面展现,以及用户登陆登出,最后用户权限的问题 正文: 首先需要在settings.py设置ROOT_URLCONF,默认值为: ROOT_URLCONF  = 'www.urls'# ...

  4. Django,COOKIES,SESSION完成用户登入

    1.urls.py """Django_cookie_session URL Configuration The `urlpatterns` list routes UR ...

  5. python编辑用户登入界面

    1.需求分析 登入界面需要达到以下要求: 系统要有登入和注册两个选项可供选择 系统要能够实现登入出错提示,比如账户密码错误等,用户信息保存在user_info.txt文件夹中 系统要能够进行登入错误次 ...

  6. python基础篇---实战---用户登入注册程序

    一.首先了解需求: 1.支持多个用户登入 2.登入成功后显示欢迎,并退出程序 3.登入三次失败后,退出程序,并在下次程序启动尝试登入时,该用户名依然是锁定状态 二.文件代码如下: f = open(& ...

  7. Oracle+struts2实现用户登入并显示访问次数

    实体类: package entity; public class userfo { private int id;//id private String name;//用户名 private Str ...

  8. MonGoDB 常见操作, 设置管理员和用户登入

    [ 启动客户端 => ./bin/mongo --host 192.168.200.100 ] 1: 查看所有已经创建的数据库  =>  show dbs   2: 切换或者创建数据库   ...

  9. 【转】vsftpd用户登入不进去问题

    实在是登陆不上... 我已经加了一个新的用户UID和GID都设置到1000以后 /etc/vsftpd.conf也加了local_enable=yes 以standalone模式运行. 重启服务器后, ...

随机推荐

  1. Install Python on Mac

    1. 从官网下载最新版Python 3.X 后安装:由于Mac OS X EI Capitan中默认已经集成了 Python 2.7,因此需要在Terminal中输入 Python3 来检测是否安装成 ...

  2. [iOS] UIFont 设置字体

    label.font = [UIFont fontWithName:@"Arial-BoldItalicMT" size:24]; 字体名如下: Font Family: Amer ...

  3. MUI框架-08-窗口管理-创建子页面

    MUI框架-08-窗口管理-创建子页面 之前写过这一篇,不知道为什么被删了,我就大概写了,抱歉 创建子页面是为了,页面切换时,外面的页面不动,让 MUI 写出来的页面更接近原生 app 官方文档:ht ...

  4. winform基础控件总结

    转自:http://www.cnblogs.com/top5/archive/2010/04/29/1724039.html 基础 - 常用控件 C# WinForm开发系列 - CheckBox/B ...

  5. 为什么java中只允许继承一个类?

      一个类只能继承一个其他的类 在Java语言中禁止多重继承:一个类可以具有多个直接父类.多重继承不合法的原因是容易引发意义不明确.例如,有一个类C,如果允许它同时继承A类与B类(class C ex ...

  6. [翻译] LazyFadeInView 渐入显示text文本

    LazyFadeInView 渐入显示text文本 https://github.com/itouch2/LazyFadeInView LazyFadeInView is a cool way to ...

  7. [翻译] ABPadLockScreen

    ABPadLockScreen ABPadLockScreen aims to provide a universal solution to providing a secure keypad/pi ...

  8. Druid学习---配置_DruidDataSource参考配置

    [更多参考]https://www.cnblogs.com/niejunlei/p/5977895.html 配置_DruidDataSource参考配置 以下是一个参考的连接池配置: <bea ...

  9. 36、XmlReader与 XMLWriter(抽象类)

    一.概述 XMLReader为抽象类,其派生类有:XmlDictionaryReader.XmlNodeReader.XmlTextReader(与IO命名空间中的TextReader对象一起使用). ...

  10. Alpha 冲刺报告(1/10)

    Alpha 冲刺报告 队名:洛基小队 峻雄(组长) 已完成:α版要完成的第一部分的游戏内容规划 明日计划:学习脚本教程,熟悉一下相关API 剩余任务:物品背包交互脚本 困难:对于JS脚本的不熟悉:如何 ...