ssh环境搭建并实现登录功能
参照了这篇博客,但是里面有些地方进行了更改
User.java和User.hbm.xml反向生成
package com.us.mine.beans; /**
* User entity. @author MyEclipse Persistence Tools
*/ public class User implements java.io.Serializable { // Fields private Integer userId;
private String userName;
private String password;
private Integer gender; // Constructors /** default constructor */
public User() {
} /** full constructor */
public User(String userName, String password, Integer gender) {
this.userName = userName;
this.password = password;
this.gender = gender;
} // Property accessors public Integer getUserId() {
return this.userId;
} public void setUserId(Integer userId) {
this.userId = userId;
} public String getUserName() {
return this.userName;
} public void setUserName(String userName) {
this.userName = userName;
} public String getPassword() {
return this.password;
} public void setPassword(String password) {
this.password = password;
} public Integer getGender() {
return this.gender;
} public void setGender(Integer gender) {
this.gender = gender;
} }
User.java
<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<!--
Mapping file autogenerated by MyEclipse Persistence Tools
-->
<hibernate-mapping>
<class name="com.us.mine.beans.User" table="user" catalog="world">
<id name="userId" type="java.lang.Integer">
<column name="userId" />
<generator class="native" />
</id>
<property name="userName" type="java.lang.String">
<column name="userName" length="16" not-null="true" />
</property>
<property name="password" type="java.lang.String">
<column name="password" length="16" not-null="true" />
</property>
<property name="gender" type="java.lang.Integer">
<column name="gender" not-null="true" />
</property>
</class>
</hibernate-mapping>
User.hbm.xml
然后是登录页,注意元素的name要和action类中的一致,form的action要和struts.xml中一致。加一个登录成功页main.jsp。
<body>
<form method="post" action="Login">
用户名:<input name="username" type="text" />
密码:<input name="password" type="password" /> <input
name="Submits" type="submit" value="登录" /> <input name="ReSet"
type="reset" value="重置" />
</form>
</body>
index.jsp
然后LoginDao,LoginDaoImpl,LoginService,LoginServiceImpl
package com.us.mine.dao;
public interface LoginDao {
boolean login(String username, String password);
}
LoginDao.java
package com.us.mine.dao;
import java.util.List;
import org.springframework.orm.hibernate3.support.HibernateDaoSupport;
import com.us.mine.beans.User;
public class LoginDaoImpl extends HibernateDaoSupport implements LoginDao {
@Override
public boolean login(String username, String password) {
List<User> u=this.getHibernateTemplate().find("from User where userName=? and password=?",username,password);
Boolean flag=false;
if(u.size()>0){
flag=true;
}
return flag;
}
}
LoginDaoImpl
package com.us.mine.service;
public interface LoginService {
boolean login(String username, String password);
}
LoginService
package com.us.mine.service; import com.us.mine.dao.LoginDao;
import com.us.mine.dao.LoginDaoImpl; public class LoginServiceImpl implements LoginService { private LoginDao logindao; public void setLogindao(LoginDaoImpl loginDao) {
this.logindao = loginDao;
} @Override
public boolean login(String username, String password) {
return logindao.login(username, password);
} }
LoginServiceImpl
然后是LoginAction 并在struts.xml中进行配置,注意action的class填写的和application里面注入的action的id相同
package com.us.mine.action; import com.opensymphony.xwork2.ActionSupport;
import com.us.mine.service.LoginService; public class LoginAction extends ActionSupport{
private LoginService loginservice;
private String password;
private String username; public LoginService getLoginservice() {
return loginservice;
} public void setLoginservice(LoginService loginservice) {
this.loginservice = loginservice;
} public String getPassword() {
return password;
} public void setPassword(String password) {
this.password = password;
} public String getUsername() {
return username;
} public void setUsername(String username) {
this.username = username;
} public String login(){
Boolean flag=loginservice.login(username, password);
if(flag){
return SUCCESS;
}else{
return INPUT;
}
}
}
LoginAction
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.1//EN" "http://struts.apache.org/dtds/struts-2.1.dtd">
<struts>
<package name="default" extends="struts-default" namespace="/">
<action name="Login" class="logina" method="login">
<result name="input">/index.jsp</result>
<result name="success">/main.jsp</result>
</action>
</package>
</struts>
struts.xml
最后是applicationContext.xml。主要是最下面3个bean,可以看到类之间的注入关系
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.1.xsd"> <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
<property name="url" value="jdbc:mysql://localhost:3306/world"></property>
<!-- 加入后解决数据库连接不上错误 -->
<property name="driverClassName" value="com.mysql.jdbc.Driver"></property>
<property name="username" value="root"></property>
<property name="password" value="1234"></property>
</bean>
<bean id="sessionFactory"
class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="dataSource">
<ref bean="dataSource" />
</property>
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">
org.hibernate.dialect.MySQLDialect
</prop>
</props>
</property>
<property name="mappingResources">
<list>
<value>com/us/mine/beans/User.hbm.xml</value>
</list>
</property>
</bean>
<bean id="UserDAO" class="com.us.mine.dao.UserDAO">
<property name="sessionFactory">
<ref bean="sessionFactory" />
</property>
</bean> <!-- Dao注入sessionFactory -->
<bean id="logind" class="com.us.mine.dao.LoginDaoImpl">
<!-- 注入持久化操作所需的SessionFactory -->
<property name="sessionFactory">
<ref bean="sessionFactory" />
</property>
</bean> <!-- service注入dao id为下面的ref class为service实现类 -->
<bean id="logins" class="com.us.mine.service.LoginServiceImpl">
<property name="logindao" ref="logind"></property>
</bean> <!-- Action注入service id="" 注入 class="action路径" name="loginservice"与LoginAction中声明的要保持一致
ref随便取 -->
<bean id="logina" class="com.us.mine.action.LoginAction" scope="prototype">
<property name="loginservice" ref="logins"></property>
</bean>
</beans>
applicationContext.xml
运行后一直报错,发现上面的配置文件少了
<property name="driverClassName" value="com.mysql.jdbc.Driver"></property>加上后可以运行
输入
ssh环境搭建并实现登录功能的更多相关文章
- SSH环境搭建之Hibernate环境搭建篇
SSH环境搭建之Hibernate环境搭建篇 搭建有两种方式: 1.使用IntelliJ IDEA或者MyEclipse的逆向工程(关系模型 -> 对象模型),我使用的是IntelliJ IDE ...
- SSH环境搭建之Spring环境搭建篇
SSH环境搭建之Spring环境搭建篇 一.引入Spring所使用的JAR文件 二.在src目录下创建beans.xml(Spring的容器文件) <?xml version="1.0 ...
- SSH环境搭建步骤解析
一.建立Java web project:AngelSSH 二.引入jar包,必要清单如下 2.1,Struts2 commons-fileupload 文件上传组件 commons-io io ...
- 阶段3 1.Mybatis_05.使用Mybatis完成CRUD_1 回顾Mybatis的环境搭建-实现查询所有功能
先回顾Mybits的环境搭建,. 直接next 直接点击finish 创建好的项目. 所有东西都自己写不现实,约束文件的头部还是拷贝过来 导入依赖坐标,Mybits mysql的驱动 log4j 单元 ...
- SSH环境搭建,配置整合初步(一)
1,新Webproject.并把编码设为utf-8(全部的都是uft8数据库也是,就不会乱码了)2.加入框架环境JunitStruts2Hibernate Spring3,整合SSHStruts2与S ...
- GateOne Web SSH 环境搭建
环境配置安装python及tornadoyum -y install python-pippip install tornado GateOne安装下载源码:git clone https://git ...
- Spring学习之SpringMVC框架快速搭建实现用户登录功能
引用自:http://blog.csdn.net/qqhjqs/article/details/41683099?utm_source=tuicool&utm_medium=referral ...
- 最新版ssh hibernate spring struts2环境搭建
最新版ssh hibernate spring struts2环境搭建 最新版spring Framework下载地址:spring4.0.0RELEASE环境搭建 http://repo.sprin ...
- Linux Ubuntu从零开始部署web环境及项目-----搭建ssh环境(一)
linux搭建ssh环境 1,用户登录 成功输入用户名和密码后 进入Ubuntu界面 2,配置网络 参考:http://blog.csdn.net/liu782726344/article/deta ...
随机推荐
- Oracle EBS-SQL (SYS-21):sys_用户名与人员对应关系查询.sql
select fu.user_name 用户名, fu.description 描述, (select ppf.FULL_NAME ...
- Adobe Acrobat 9 Pro 简体中文正式版(免激活)
软件语言:简体中文版本性质:官方正式版(免激活,非破解) Mac & PC [SN]: 1118-4018-6583-4956-2486-7805 修改 Abcpy.ini 可实现免序列号免激 ...
- 如何在Delphi中调用VC6.0开发的COM
上次写了如何在VC6.0下对Delphi写的COM进行调用,原本想马上写如何在Delphi中调用VC6.0开发的COM时,由于在写事例程序中碰到了个很怪的问题,在我机子上用VC写的接口程序编译能通过. ...
- 将外部准备好的sqlite导入到项目当中
首先,将sqlite数据库文件放在Resource文件夹下,并且允许其编译到项目当中. 之后在AppDelegate当中执行一些代码,这里将代码封装了一个Helper: #import "R ...
- 修改UISearchBar背景颜色
UISearchBar是由两个subView组成的,一个是UISearchBarBackGround,另一个是UITextField. 要IB中没有直接操作背景的属性.方法一:是直接将 UISearc ...
- 注意:只有xcode5.1创建的项目会自动适配iphone6,iphone6p
注意:只有xcode5.1创建的项目会自动适配iphone6,iphone6p
- Binding 之ObjectDataProvider数据源
ObjectDataProvider数据源它可以把对象作为数据源提供给Binding,可用于绑定函数, 实例如下 public partial class BindObiectDataProvider ...
- HBase API详解
一.Java API和HBase数据模型的关系 在Java中,与HBase数据库存储管理相关的类包括HBaseAdmin.HBaseConfiguration.HTable.HTableDescrip ...
- 解决Thinkpad E450 外接显示器后没有声音的问题
昨天把公司配的ThinkPad E450 带回来了,今天用的时候一切正常没什么问题. 因为要看边看视频边做点别的,我就外接一台显示器,说出来我的这台显示器,你们绝对想不到是什么 显示器.我的这台显示器 ...
- MySQL学习系列一---命令行连接mysql和执行sql文件
1.命令行连接mysql #mysql -h(主机) -u(用户名) -p (数据库名) mysql -hlocalhost -uroot -p testdb Enter password: **** ...