spring+springmvc+hibernate入门:完成注册实例测试

    初入公司,处于被闲置自力更生的状态,看到公司项目有使用ssh的架构,之前只接触过ssm的,便尝试一番,大有所获,特来总结一下。

    搭建基本的maven项目,之后的目录基本如下,不需急于创建详细的目录,一步一步来!

    spring+springmvc+hibernate入门:完成注册实例测试_第1张图片

    在之前很长一段时间,一直搞不清spring应该有哪些依赖,看到很多博客上也是直接就丢一堆上去,后来去花时间查了下,我们在web项目上使用springmvc,只需要一个即可



	org.springframework
	spring-webmvc
	${spring.version}

对了,为了方便,版本如下


	UTF-8
	5.0.6.RELEASE
	5.1.7.Final

因为spring-webmvc依赖于其它的spring核心的包,所以上面本身就包含它们了,具体可到:点击打开链接 学习spring各依赖之间的关系。

下面是web.xml



	ssh
	
		index.html
		index.htm
		index.jsp
		default.html
		default.htm
		default.jsp
	

	
	
	
		encodingFilter
		org.springframework.web.filter.CharacterEncodingFilter
		
			encoding
			UTF-8
		
		
			forceEncoding
			true
		
	
	
		encodingFilter
		/*
	
	
	
	
		springmvc
		org.springframework.web.servlet.DispatcherServlet
		
			contextConfigLocation
			classpath:spring-mvc.xml
		
		1
	
	
		springmvc
		/
	

随后是spring-mvc.xml这里我直接放在resources下,即classpath直接访问到的位置




	
	
	

	
	

	
	

	
	
		
		
		
		
	

主目录src/main/java下包ssh.mvc.controller创建测试类TestController.java

package ssh.mvc.controller;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;

@Controller
public class TestController {
	@RequestMapping("/test")
	public String test() {
		return "test";
	}
}

在WEB-INF下新建文件夹view,之后创建一个jsp文件 test.jsp这里的文件名(上面return 后双引号里面部分即为要访问的jsp文件名) 该文件随意在body输入点内容

使用tomocat启动项目,正常启动后,访问 http://localhost:8080/ssh/test 可以看到刚才随意输入的内容即为成功

至此,springmvc环境搭建好了!之后需要加入的依赖就多一些了



        org.hibernate
	hibernate-core
	${hibernate.version}



	org.hibernate
	hibernate-c3p0
	${hibernate.version}



	mysql
	mysql-connector-java
	5.1.34



	org.projectlombok
	lombok
	1.16.18

这里的依赖具体自行查明用意,lombok可不用,不过相应的实体类自行添加get、set、toString等

我们添加spring监听器来配置dao层的东西,避免混乱

在web.xml下添加以下代码


	
		org.springframework.web.context.ContextLoaderListener
	
	
		contextConfigLocation
		classpath:dao.xml
	

在spring-mvc.xml的位置新建文件jdbc.properties和dao.xml

jdbc.properties

user=root
password=root
url=jdbc:mysql://localhost:3306/ssh?useUnicode=true&characterEncoding=utf8
driverClass=com.mysql.jdbc.Driver

dao.xml



	
	
	
	
		
		
		
		
	
	
	 
    
        
        
            
                org.hibernate.dialect.MySQLDialect
                update
                true
                true
            
        
        
    

新建包ssh.mvc.entity下面新建实体类User

package ssh.mvc.entity;

import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Table;

import lombok.Data;

@Table(name="user")
@Entity
@Data
public class User {
	@GeneratedValue(strategy=GenerationType.IDENTITY)
	@Id
	private Integer id;
	private String username;
	private String password;
	private String nickname;
}

@Data即为lombok的一个注解,使用后可省下生成getset方法的时间等,@GeneratedValue后的设置为主键自增

至此,保存后启动服务器,可以看到在数据库中自动生成了表user

ssh.mvc.dao下UserDao

package ssh.mvc.dao;

import ssh.mvc.entity.User;

public interface UserDao {
	public void addUser(User user);
}

在建子包impl,即(ssh.mvc.dao.impl)下UserDaoImpl

package ssh.mvc.dao.impl;

import org.hibernate.SessionFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Repository;
import org.springframework.transaction.annotation.Transactional;

import ssh.mvc.dao.UserDao;
import ssh.mvc.entity.User;
@Repository("userDao")
@Transactional
public class UserDaoImpl implements UserDao{
	@Autowired
	private SessionFactory sessionFactory;
	
	public void addUser(User user) {
		sessionFactory.openSession().save(user);
	}
}

同理,service层面也是如此

package ssh.mvc.service;

import ssh.mvc.entity.User;

public interface UserService {
	void addOne(User user);
}
package ssh.mvc.service.impl;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import ssh.mvc.dao.UserDao;
import ssh.mvc.entity.User;
import ssh.mvc.service.UserService;

@Service
public class UserServiceImpl implements UserService{
	@Autowired
	private UserDao userDao;
	
	public void addOne(User user) {
		userDao.addUser(user);
	}
}

最后是控制层

package ssh.mvc.controller;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;

import ssh.mvc.entity.User;
import ssh.mvc.service.UserService;

@Controller
@RequestMapping("/user")
public class UserController {
	@Autowired
	private UserService userService;
	
	@RequestMapping("/addOne")
	@ResponseBody
	public String register(User user) {
		System.out.println(user.getUsername());
		userService.addOne(user);
		return "注册成功!";
	}
}

OK,来一个简单的测试,保存启动服务器

http://localhost:8080/ssh/user/addOne?username=张三&password=2&nickname=2

可以看到返回了几个????,数据成功插入了数据库

这明显是没有弄好乱码处理的结果

在spring-mvc.xml中的标签里添加处理配置

	
	
		
		
			
				
				
				
			
		
	

注意:这里必须放在标签之前,即扫描包之前

OK,再次测试即可看到返回注册成功,并且数据库也插入成功!

注意的是:当你多玩了些别的操作就会发现问题,我们需要做个措施防止

 org.hibernate.HibernateException: Could not obtain transaction-synchronized 

Session for current 出错问题

pom.xml加入相关依赖


	org.springframework
	spring-orm
	${spring.version}



	org.aspectj
	aspectjweaver
	1.8.10

dao.xml配置事务管理


	

	
	
		
	

	
	

在web.xml中加入如下代码


	
		SpringOpenSessionInViewFilter
		org.springframework.orm.hibernate5.support.OpenSessionInViewFilter
	
	
		SpringOpenSessionInViewFilter
		/*
	


并在相应方法或者控制类上添加@Transactional注解,具体可~自己查

新人总结,如有问题,大佬勿喷~Thanks♪(・ω・)ノ


你可能感兴趣的:(java)