ssh为 struts+spring+hibernate的一个集成框架,是目前较流行的一种Web应用程序开源框架。
1. struts2
struts2是一个基于MVC模式设计的web应用框架,其实它在的功能和servlet一样在,框架中主要起到的作用就是链接前端的试图层页面,处理页面的请求。
2.spring
Spring是一个轻量级控制反转(IoC)和面向切面(AOP)的容器框架,而在我看来呢Spring就好比是一个多口味的火锅,能让你在吃各种火锅的同时又不至于让多种味道混合在一起,能让各种各样的框架通过它来进行组装和整合的同时还能相互独立,既能很好的融合又不至于相互影响。
轻量——从大小与开销两方面而言Spring都是轻量的。完整的Spring框架可以在一个大小只有1MB多的JAR文件里发布。并且Spring所需的处理开销也是微不足道的。此外,Spring是非侵入式的:典型地,Spring应用中的对象不依赖于Spring的特定类。
控制反转——Spring通过一种称作控制反转(IoC)的技术促进了松耦合。当应用了IoC,一个对象依赖的其它对象会通过被动的方式传递进来,而不是这个对象自己创建或者查找依赖对象。你可以认为IoC与JNDI相反——不是对象从容器中查找依赖,而是容器在对象初始化时不等对象请求就主动将依赖传递给它。
面向切面——Spring提供了面向切面编程的丰富支持,允许通过分离应用的业务逻辑与系统级服务(例如审计(auditing)和事务(transaction)管理)进行内聚性的开发。应用对象只实现它们应该做的——完成业务逻辑——仅此而已。它们并不负责(甚至是意识)其它的系统级关注点,例如日志或事务支持。
容器——Spring包含并管理应用对象的配置和生命周期,在这个意义上它是一种容器,你可以配置你的每个bean如何被创建——基于一个可配置原型(prototype),你的bean可以创建一个单独的实例或者每次需要时都生成一个新的实例——以及它们是如何相互关联的。然而,Spring不应该被混同于传统的重量级的EJB容器,它们经常是庞大与笨重的,难以使用。
框架——Spring可以将简单的组件配置、组合成为复杂的应用。在Spring中,应用对象被声明式地组合,典型地是在一个XML文件里。Spring也提供了很多基础功能(事务管理、持久化框架集成等等),将应用逻辑的开发留给了你。
3.hibernate
hibernate是一种数据库持久层的封装框架,在框架中的作用就是处理数据与数据库间的交互,它的好处呢就是将JDBC进行了很好的封装,并且能和POJO类进行相应的映射在编程时能够省略大量代码。
下面是框架搭建的步骤
1.Struts的建立
- [第一步] 导入jar包
这些是SSH框架相应的jar包
- [第二步] 配置web.xml文件
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
version="4.0">
<!-- struts2的过滤器 -->*加粗样式*
<filter>
<filter-name>struts2</filter-name>
<filter-class>
org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter
</filter-class>
</filter>
<filter-mapping>
<filter-name>struts2</filter-name>
<!-- 拦截所有请求 请求文件 不能进入 工程 *.action-->
<url-pattern>/*</url-pattern>
</filter-mapping>
</web-app>
在web.xml中配置的这个是一个过滤器。通过过滤器能将所以请求后缀为*.action的请求转到struts.xml中
- [第三步 ] 就是配置struts.xml文件 这个struts.xml 是要自己建立的在src的根目录下一定要注意struts.xml文件名千万别写错 写错了就会导致请求失败
- 下面是struts.xml的代码
?xml version="1.0" encoding="GBK"?>
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
"http://struts.apache.org/dtds/struts-2.0.dtd">
<struts>
<include file="struts-default.xml" />
<!--在这个 package中的 name是package的名在这个name是唯一的不可重复
extedns就是继承的意思 这个package就继承了struts-default
-->
<package name="hello" extends="struts-default">
<!-- action中的name呢 是对应拦截器的名字 也就是你在前端的jsp页面的 *.action 中的*
而class呢则是对应了后端的action类了 而method所对应的就是在action类中的方法了
-->
<action name="hello" class="com.gsh.ssh.action.HelloAction" method="Hello">
<!-- 参数设置
result 是设置方法的返回值 和返回的液面
name:对应Action中的get/set方法
/jsp/Hello.jsp这个对应返回到的页面
-->
<result name="success">/jsp/Hello.jsp</result>
</action>
</package>
</struts>
配置完struts.xml之后根据struts.xml中的配置就回进入到相应的Java类中的方法 下面是相应的Java类的代码
- [第四部 ] 编写HelloAction类
package com.gsh.ssh.action;
import com.opensymphony.xwork2.ActionSupport;
public class HelloAction extends ActionSupport {
public String a;
public String Hello(){
a="Hello";
return SUCCESS;
}
//这个地方一定要对你所传的值进行set get方法 这个是方法的封装向前端传值的方法
public String getA() {
return a;
}
public void setA(String a) {
this.a = a;
}
}
对应的java类一定要继承于ActionSupport这个类 ,另外需要注意的是当你向前端传输一个值或一组值的时候一定要对相应的参数进行set和get方在struts中他将像前端传输值的方法封装在了set 和 get方法中。
这是hello.jsp的代码
<%--
Created by IntelliJ IDEA.
User: GSH
Date: 2019/2/21
Time: 18:41
To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Title</title>
</head>
<body>
${a}
</body>
</html>
配置完成后启动项目手动在地址栏上敲http://localhost:8080/hello.action
这时如果进入到了 Hello.jsp界面并在显示了hello这时就证明struts的基本配置就成功了。
对应struts的流程图如下
- 引入spring
- [第一步 ] 导入Spring与struts结合的jar包
这个是spring与struts整合jar包在spring和struts整合中一定要加入这个包
- [第二部 ] 配置web.xml文件建立spring监听器。
<!-- spring -->
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>/WEB-INF/spring.xml</param-value>
</context-param>
这是Spring监听器的配置代码Spring通过监听器将请求在Spring.xml中进行比对
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">
<!-- 这个是与数据库链接的 创建与数据库的链接-->
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="driverClassName">
<value>com.mysql.jdbc.Driver</value>
</property>
<property name="url">
<value>jdbc:mysql://localhost:3306/hero?useSSL=false</value>
</property>
<property name="username">
<value>root</value>
</property>
<property name="password">
<value>123456</value>
</property>
</bean>
<!--这个是和struts链接的-->
<bean id="HelloAction" class="com.gsh.ssh.action.HelloAction">
<!--这个是在HelloAction 中定义的类 而这里的设置呢就是起到的一个new的作用
将Service类引入到HelloAction中
name呢就是对应的定义出来的参数的名字
local则对应的是下面定义的Service类
-->
<property name="service">
<ref local="Service"/>
</property>
</bean>
<!-- 这个是service层 -->
<bean id="Service" class="com.gsh.ssh.action.Service">
<!--这个是在Service 中定义的类 而这里的设置呢就是起到的一个new的作用
将Dao类引入到Service中-->
<property name="dao">
<ref local="Dao"/>
</property>
</bean>
<!-- 这个是dao层 -->
<bean id="Dao" class="com.gsh.ssh.action.Dao">
<!--这里面的name对应的呢就是上面的与数据的链接 因为dao层中的这个类是用来处理数据的
所以要将与数据库的链接引入到dao中去
-->
<property name="dataSource">
<ref local="dataSource"/>
</property>
</bean>
</beans>
Spring的作用呢就是对类进行注入,类与类之间的关系都是由Spring来配置的在一个类调用另一个类中的方法时不再是主动的去创建这个对象或者是调用已创建的对象,而是在当你运行到这个程序的时候Ioc容器会主动创建一个对象注入到其中去,这样在满足需求的同时又降低了对其他类的依赖,轻松做到了解耦和。
Service的代码
package com.gsh.ssh.action;
public class Service {
public Dao dao;
public void query() {
dao.query();
}
//对Dao这个类进行set 和 get才能让Spring将这个类注入
public Dao getDao() {
return dao;
}
public void setDao(Dao dao) {
this.dao = dao;
}
}
Dao的代码
package com.gsh.ssh.action;
import org.springframework.jdbc.core.JdbcTemplate;
public class Dao extends JdbcTemplate {
public void query() {
String sql = "select * from class";
System.out.println(this.queryForList(sql));
}
}
Dao中继承的类是为了执行sql语句 之后整合上hibernate时继承的类将会发生改变
这是Spring加Struts的流程
- 引入hibernate
hibernate的作用呢就是对数据库的操作进行了封装,能够让数据库中的数据和后端创建的pojo类进行对应让在执行数据库的操作时取出的数据能和类中的数据类型一一对应。
这是最终的web.xml文件的配置
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">
<!-- 这个是与数据库链接的 创建与数据库的链接-->
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="driverClassName">
<value>com.mysql.jdbc.Driver</value>
</property>
<property name="url">
<value>jdbc:mysql://localhost:3306/hero?useSSL=false</value>
</property>
<property name="username">
<value>root</value>
</property>
<property name="password">
<value>123456</value>
</property>
</bean>
<!--Hibernate 的配置-->
<!--创建一个sessio工厂 将数据的处理交给hibernate去执行-->
<bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<!--Hibernate 链接数据库的配置 通过 spring 传递给Hibernate-->
<property name="dataSource">
<ref local="dataSource"/>
</property>
<!--配置的是Hibernate的xml文件路径-->
<property name="mappingResources">
<list>
<!--这个对应的是hrb的配置文件-->
<value>com/gsh/ssh/Pojo/student.hrb.xml</value>
</list>
</property>
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect</prop>
<prop key="hibernate.show_sql">true</prop>
<prop key="hibernate.jdbc.batch_size">20</prop>
<prop key="hibernate.hbm2ddl.auto">update</prop>
</props>
</property>
</bean>
<!--这个是和struts链接的-->
<bean id="HelloAction" class="com.gsh.ssh.action.HelloAction">
<!--这个是在HelloAction 中定义的类 而这里的设置呢就是起到的一个new的作用
将Service类引入到HelloAction中
name呢就是对应的定义出来的参数的名字
local则对应的是下面定义的Service类
-->
<property name="service">
<ref local="Service"/>
</property>
</bean>
<!-- 这个是service层 -->
<bean id="Service" class="com.gsh.ssh.action.Service">
<!--这个是在Service 中定义的类 而这里的设置呢就是起到的一个new的作用
将Dao类引入到Service中-->
<property name="dao">
<ref local="Dao"/>
</property>
</bean>
<!-- 这个是dao层 -->
<bean id="Dao" class="com.gsh.ssh.action.Dao">
<!--在引入了hibernate之后数据的操作就交给了hibernate进行处理了
所以当进行数据处理的时候只需要将hibernate的session工厂注入就可以了
-->
<property name="sessionFactory">
<ref local="sessionFactory"/>
</property>
</bean>
</beans>
student.hrb.xml的配置
<?xml version="1.0" encoding="UTF-8"?>
<!-- 这是Hibernate的配置文件主要做的是将pojo类和数据库中的值相对应起来 -->
<!DOCTYPE hibernate-mapping
PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
<!-- Student -> 数据库 的映射文件
class 中的name对应的时pojo类的路径
table对应的时数据库中的表名
-->
<class name="com.gsh.ssh.Pojo.Student" table="student">
<!--这个id对应的时数据库中表的主键
name时pojo类中的变量的名称
column对应的是在数据库中的字段名
-->
<id name="id" column="id">
<!--对应的是主键自动增加 -->
<generator class="identity"/>
</id>
<property name="name" column="name" />
<property name="age" column="age" />
<property name="school" column="schoo" />
<property name="sex" column="sex" />
</class>
</hibernate-mapping>
这个里面的配置的名一定要和相对应的pojo类中的属性一一对应,而在创建pojo类的时候要尽量与数据库中对应的表名相同否则出差的可能性会很大如果不一样则应该在类上面进行注释
@Table(name="_student") //表示Student类对应_student这张表
对应的Dao也有改动
package com.gsh.ssh.action;
import com.gsh.ssh.Pojo.Student;
import org.springframework.orm.hibernate3.support.HibernateDaoSupport;
import java.util.ArrayList;
public class Dao extends HibernateDaoSupport {
ArrayList<Student> Students = new ArrayList<Student>();
public ArrayList<Student> query() {
String hql = "from Student";
return Students = (ArrayList<Student>) this.getHibernateTemplate().find(hql);
}
}
因为现在引入了hrb所以执行的sql语句就变成了hql语句Dao类所继承类也有所改变,变成了这个HibernateDaoSupport。
最后运行项目
能在页面打印出数据SSH框架就搭建成功了。