【Spring实战-3】Spring整合Hibernate、Struts
1. 摘要
- 项目结构的规划;
- Spring下整合Hibernate的具体过程;
- 整合struts的过程;
- 重点介绍Dao层的设计;
2. 项目结构




3. web.xml

<?xml version="1.0" encoding="GBK"?><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/javaeehttp://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd" version="3.1"><listener><listener-class>org.springframework.web.context.ContextLoaderListener</listener-class></listener><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><url-pattern>/*</url-pattern></filter-mapping><welcome-file-list><welcome-file>/WEB-INF/content/bookForm.jsp</welcome-file></welcome-file-list></web-app>
4. applicationContext.xml
主要完成了如下工作:
- 首先需要配置 数据源,这里使用C3P0数据源;
- 配置sessionFactory;
- 配置Hibernate事务管理器;
- 配置切入点、通告等;







<?xml version="1.0" encoding="GBK"?><beans xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xmlns="http://www.springframework.org/schema/beans"xmlns:p="http://www.springframework.org/schema/p"xmlns:tx="http://www.springframework.org/schema/tx"xmlns:aop="http://www.springframework.org/schema/aop"xsi:schemaLocation="http://www.springframework.org/schema/beanshttp://www.springframework.org/schema/beans/spring-beans-4.0.xsdhttp://www.springframework.org/schema/txhttp://www.springframework.org/schema/tx/spring-tx-4.0.xsdhttp://www.springframework.org/schema/aophttp://www.springframework.org/schema/aop/spring-aop-4.0.xsd"><!-- 定义数据源Bean,使用C3P0数据源实现,并注入数据源的必要信息 --><bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource"destroy-method="close"p:driverClass="com.mysql.jdbc.Driver"p:jdbcUrl="jdbc:mysql://localhost:3306/sampledb"p:user="root"p:password="qaz"p:maxPoolSize="40"p:minPoolSize="2"p:initialPoolSize="2"p:maxIdleTime="30"/><!-- 定义Hibernate的SessionFactory,SessionFactory需要依赖数据源,注入dataSource --><bean id="sessionFactory"class="org.springframework.orm.hibernate4.LocalSessionFactoryBean"p:dataSource-ref="dataSource"><!-- annotatedClasses用来列出全部持久化类 --><property name="annotatedClasses"><list><!-- 以下用来列出所有的PO类--><value>org.crazyit.booksys.domain.Book</value></list></property><!-- 定义Hibernate SessionFactory的属性 --><property name="hibernateProperties"><props><!-- 指定Hibernate的连接方言 --><prop key="hibernate.dialect">org.hibernate.dialect.MySQL5InnoDBDialect</prop><!--是否根据Hiberante映射创建数据表 --><prop key="hibernate.hbm2ddl.auto">update</prop><prop key="hibernate.show_sql">true</prop><prop key="hibernate.format_sql">true</prop></props></property></bean><!-- 定义Service组件,并将DAO组件注入Service组件 --><bean id="bookService" class="org.crazyit.booksys.service.impl.BookServiceImpl"p:bookDao-ref="bookDao"/><!-- 定义DAO组件,并将SessionFactory注入DAO组件 --><bean id="bookDao" class="org.crazyit.booksys.dao.impl.BookDaoHibernate4"p:sessionFactory-ref="sessionFactory"/><!-- 配置Hibernate的局部事务管理器,使用HibernateTransactionManager类 --><!-- 该类是PlatformTransactionManager接口针对采用Hibernate的特定实现类 --><!-- 配置HibernateTransactionManager需依赖注入SessionFactory --><bean id="transactionManager"class="org.springframework.orm.hibernate4.HibernateTransactionManager"p:sessionFactory-ref="sessionFactory"/><!-- 配置事务增强处理Bean,指定事务管理器 --><tx:advice id="txAdvice"transaction-manager="transactionManager"><!-- 用于配置详细的事务定义 --><tx:attributes><!-- 所有以'get'开头的方法是read-only的 --><tx:method name="get*" read-only="true"/><!-- 其他方法使用默认的事务设置,指定超时时长为5秒 --><tx:method name="*" isolation="DEFAULT"propagation="REQUIRED" timeout="5"/></tx:attributes></tx:advice><!-- AOP配置的元素 --><aop:config><!-- 配置一个切入点 --><aop:pointcut id="myPointcut" expression="bean(bookService)"/><!-- 指定在myPointcut切入点应用txAdvice事务增强处理 --><aop:advisor advice-ref="txAdvice"pointcut-ref="myPointcut"/></aop:config></beans>


<?xml version="1.0" encoding="GBK"?><!-- 指定Struts 2配置文件的DTD信息 --><!DOCTYPE struts PUBLIC"-//Apache Software Foundation//DTD Struts Configuration 2.3//EN""http://struts.apache.org/dtds/struts-2.3.dtd"><struts><!-- 配置了系列常量 --><constant name="struts.i18n.encoding" value="GBK"/><constant name="struts.enable.DynamicMethodInvocation" value="false" /><constant name="struts.devMode" value="true"/><package name="lee" extends="struts-default"><action name="addBook" class="org.crazyit.booksys.action.BookAction"method="add"><!-- 添加图书成功,列出所有图书 --><result type="chain">listBooks</result><!-- 添加图书失败,跳转到添加图书的表单页 --><result name="error">/WEB-INF/content/bookForm.jsp</result></action><action name="listBooks" class="org.crazyit.booksys.action.BookAction"method="list"><result>/WEB-INF/content/listBooks.jsp</result></action><action name="deleteBook" class="org.crazyit.booksys.action.BookAction"method="delete"><result type="chain">listBooks</result></action><!-- 让用户直接访问该应用时列出所有视图页面 --><action name="*"><result>/WEB-INF/content/{1}.jsp</result></action></package></struts>
6. Dao层设计
项目时分层设计结构,分为控制层、业务层、持久层(Dao)层、PO层(持久化对象),如下图:


- 根据ID加载实体;
- 保存实体;
- 更新实体;
- 删除实体;
- 根据ID删除实体;
- 获取所有实体;
- 获取实体总数;
- 等等等;


package org.crazyit.common.dao;import java.util.List;import java.io.Serializable;public interface BaseDao<T>{// 根据ID加载实体T get(Class<T> entityClazz , Serializable id);// 保存实体Serializable save(T entity);// 更新实体void update(T entity);// 删除实体void delete(T entity);// 根据ID删除实体void delete(Class<T> entityClazz , Serializable id);// 获取所有实体List<T> findAll(Class<T> entityClazz);// 获取实体总数long findCount(Class<T> entityClazz);}
* ==>==> BaseDaoHibernate3.java








package org.crazyit.common.dao.impl;import org.hibernate.*;import java.util.List;import java.io.Serializable;import org.crazyit.common.dao.*;/************************************ 1. Spring推荐使用sessionFactory的getCurrentSession()来获取Session,* 然后通过Session进行持久化操作。 ==> BaseDaoHibernate4.java** 2. Spring并不推荐使用HibernateTemplate、HibernateDaoSupport来实现Dao组件,* Spring4为了和以前编码风格兼容,才提供了HibernateTemplate、HibernateDaoSupport;* ==>==> BaseDaoHibernate3.java************************************/public class BaseDaoHibernate4<T> implements BaseDao<T>{// DAO组件进行持久化操作底层依赖的SessionFactory组件private SessionFactory sessionFactory;// 依赖注入SessionFactory所需的setter方法public void setSessionFactory(SessionFactory sessionFactory){this.sessionFactory = sessionFactory;}public SessionFactory getSessionFactory(){return this.sessionFactory;}// 根据ID加载实体@SuppressWarnings("unchecked")public T get(Class<T> entityClazz , Serializable id){return (T)getSessionFactory().getCurrentSession().get(entityClazz , id);}// 保存实体public Serializable save(T entity){return getSessionFactory().getCurrentSession().save(entity);}// 更新实体public void update(T entity){getSessionFactory().getCurrentSession().saveOrUpdate(entity);}// 删除实体public void delete(T entity){getSessionFactory().getCurrentSession().delete(entity);}// 根据ID删除实体public void delete(Class<T> entityClazz , Serializable id){getSessionFactory().getCurrentSession().createQuery("delete " + entityClazz.getSimpleName()+ " en where en.id = ?0").setParameter("0" , id).executeUpdate();}// 获取所有实体public List<T> findAll(Class<T> entityClazz){return find("select en from "+ entityClazz.getSimpleName() + " en");}// 获取实体总数public long findCount(Class<T> entityClazz){List<?> l = find("select count(*) from "+ entityClazz.getSimpleName());// 返回查询得到的实体总数if (l != null && l.size() == 1 ){return (Long)l.get(0);}return 0;}// 根据HQL语句查询实体@SuppressWarnings("unchecked")protected List<T> find(String hql){return (List<T>)getSessionFactory().getCurrentSession().createQuery(hql).list();}// 根据带占位符参数HQL语句查询实体@SuppressWarnings("unchecked")protected List<T> find(String hql , Object... params){// 创建查询Query query = getSessionFactory().getCurrentSession().createQuery(hql);// 为包含占位符的HQL语句设置参数for(int i = 0 , len = params.length ; i < len ; i++){query.setParameter(i + "" , params[i]);}return (List<T>)query.list();}/*** 使用hql 语句进行分页查询操作* @param hql 需要查询的hql语句* @param pageNo 查询第pageNo页的记录* @param pageSize 每页需要显示的记录数* @return 当前页的所有记录*/@SuppressWarnings("unchecked")protected List<T> findByPage(String hql,int pageNo, int pageSize){// 创建查询return getSessionFactory().getCurrentSession().createQuery(hql)// 执行分页.setFirstResult((pageNo - 1) * pageSize).setMaxResults(pageSize).list();}/*** 使用hql 语句进行分页查询操作* @param hql 需要查询的hql语句* @param params 如果hql带占位符参数,params用于传入占位符参数* @param pageNo 查询第pageNo页的记录* @param pageSize 每页需要显示的记录数* @return 当前页的所有记录*/@SuppressWarnings("unchecked")protected List<T> findByPage(String hql , int pageNo, int pageSize, Object... params){// 创建查询Query query = getSessionFactory().getCurrentSession().createQuery(hql);// 为包含占位符的HQL语句设置参数for(int i = 0 , len = params.length ; i < len ; i++){query.setParameter(i + "" , params[i]);}// 执行分页,并返回查询结果return query.setFirstResult((pageNo - 1) * pageSize).setMaxResults(pageSize).list();}}
- getHibernateTemplate():获取HibernateTemplate,通过HibernateTemplate来实现数据库操作;
- setSessionFactory():使用spring的依赖注入;






package org.crazyit.common.dao.impl;import java.io.Serializable;import java.util.List;import org.crazyit.common.dao.BaseDao;import org.hibernate.*;import org.springframework.orm.hibernate4.support.HibernateDaoSupport;import org.springframework.orm.hibernate4.HibernateCallback;/************************************ 1. Spring推荐使用sessionFactory的getCurrentSession()来获取Session,* 然后通过Session进行持久化操作。 ==> BaseDaoHibernate4.java** 2. Spring并不推荐使用HibernateTemplate、HibernateDaoSupport来实现Dao组件,* Spring4为了和以前编码风格兼容,才提供了HibernateTemplate、HibernateDaoSupport;* ==>==> BaseDaoHibernate3.java************************************/public class BaseDaoHibernate3<T> extends HibernateDaoSupportimplements BaseDao<T>{// 根据ID加载实体public T get(Class<T> entityClazz, Serializable id){return getHibernateTemplate().get(entityClazz, id);}// 保存实体public Serializable save(T entity){return getHibernateTemplate().save(entity);}// 更新实体public void update(T entity){getHibernateTemplate().saveOrUpdate(entity);}// 删除实体public void delete(T entity){getHibernateTemplate().delete(entity);}// 根据ID删除实体public void delete(Class<T> entityClazz, Serializable id){delete(get(entityClazz , id));}@Override@SuppressWarnings("unchecked")public List<T> findAll(Class<T> entityClazz){return (List<T>)getHibernateTemplate().find("select en from "+ entityClazz.getSimpleName() + " en");}@Override@SuppressWarnings("unchecked")public long findCount(Class<T> entityClazz){List<Long> list = (List<Long>)getHibernateTemplate().find("select count(*) from " + entityClazz.getSimpleName() + " en");return list.get(0);}/*** 使用hql 语句进行分页查询操作* @param hql 需要查询的hql语句* @param pageNo 查询第pageNo页的记录* @param pageSize 每页需要显示的记录数* @return 当前页的所有记录*/@SuppressWarnings("unchecked")protected List<T> findByPage(final String hql,final int pageNo, final int pageSize){// 通过一个HibernateCallback对象来执行查询List<T> list = getHibernateTemplate().execute(new HibernateCallback<List<T>>(){// 实现HibernateCallback接口必须实现的方法public List<T> doInHibernate(Session session){// 执行Hibernate分页查询List<T> result = session.createQuery(hql).setFirstResult((pageNo - 1) * pageSize).setMaxResults(pageSize).list();return result;}});return list;}/*** 使用hql 语句进行分页查询操作* @param hql 需要查询的hql语句* @param pageNo 查询第pageNo页的记录* @param pageSize 每页需要显示的记录数* @param params 如果hql带占位符参数,params用于传入占位符参数* @return 当前页的所有记录*/@SuppressWarnings("unchecked")protected List<T> findByPage(final String hql , final int pageNo,final int pageSize , final Object... params){// 通过一个HibernateCallback对象来执行查询List<T> list = getHibernateTemplate().execute(new HibernateCallback<List<T>>(){// 实现HibernateCallback接口必须实现的方法public List<T> doInHibernate(Session session){// 执行Hibernate分页查询Query query = session.createQuery(hql);// 为包含占位符的HQL语句设置参数for(int i = 0 , len = params.length ; i < len ; i++){query.setParameter(i + "" , params[i]);}List<T> result = query.setFirstResult((pageNo - 1) * pageSize).setMaxResults(pageSize).list();return result;}});return list;}}
6.2 dao层具体类的实现



package org.crazyit.booksys.dao;import org.crazyit.booksys.domain.Book;import org.crazyit.common.dao.BaseDao;public interface BookDao extends BaseDao<Book>{}

package org.crazyit.booksys.dao.impl;import org.crazyit.booksys.dao.BookDao;import org.crazyit.booksys.domain.Book;import org.crazyit.common.dao.impl.BaseDaoHibernate4;/*** Spring推荐使用继承前面的BaseDaoHibernate4,也可以继承前面的BaseDaoHibernate3*/public class BookDaoHibernate4 extends BaseDaoHibernate4<Book>implements BookDao{}
对应的spring配置==>依赖注入:sessionFactory;


package org.crazyit.booksys.domain;import javax.persistence.*;@Entity@Table(name="book_inf")public class Book{@Id @Column(name="book_id")@GeneratedValue(strategy=GenerationType.IDENTITY)private Integer id;@Column(name="book_name")private String name;private double price;private String author;public Integer getId(){return id;}public void setId(Integer id){this.id = id;}public String getName(){return name;}public void setName(String name){this.name = name;}public double getPrice(){return price;}public void setPrice(double price){this.price = price;}public String getAuthor(){return author;}public void setAuthor(String author){this.author = author;}}
因为我们在spring的配置文件中配置了:



所以当我们第一次运行程序,执行数据库操作时,会在数据库中自动生成数据表:

8. 控制层和业务层
控制层:BookAction.java



package org.crazyit.booksys.action;import java.util.List;import org.crazyit.booksys.domain.Book;import org.crazyit.booksys.service.BookService;import com.opensymphony.xwork2.ActionSupport;public class BookAction extends ActionSupport{private BookService bookService; //业务层组件private Book book;private List<Book> books;private int id;// 处理添加图书的add()方法public String add(){if(book == null){book = new Book();book.setAuthor("zhangsan");book.setName("zhangsan");book.setPrice(123);}// 调用业务逻辑组件的addBook()方法来处理用户请求int result = bookService.addBook(book);if(result > 0){addActionMessage("恭喜您,图书添加成功!");return SUCCESS;}addActionError("图书添加失败,请重新输入!");return ERROR;}public String list(){setBooks(bookService.getAllBooks());return SUCCESS;}public String delete(){bookService.deleteBook(id);return SUCCESS;}public void setBookService(BookService bookService){this.bookService = bookService;}public Book getBook(){return book;}public void setBook(Book book){this.book = book;}public List<Book> getBooks(){return books;}public void setBooks(List<Book> books){this.books = books;}public int getId(){return id;}public void setId(int id){this.id = id;}}
bookService 采用依赖注入的方式:

package org.crazyit.booksys.service;import java.util.List;import org.crazyit.booksys.domain.Book;public interface BookService{// 添加图书int addBook(Book book);List<Book> getAllBooks();void deleteBook(int id);}
实现类:BookServiceImpl.java

package org.crazyit.booksys.service.impl;import java.util.List;import org.crazyit.booksys.dao.BookDao;import org.crazyit.booksys.domain.Book;import org.crazyit.booksys.service.BookService;public class BookServiceImpl implements BookService{private BookDao bookDao;public void setBookDao(BookDao bookDao){this.bookDao = bookDao;}@Overridepublic int addBook(Book book){return (Integer) bookDao.save(book);}@Overridepublic List<Book> getAllBooks(){return bookDao.findAll(Book.class);}@Overridepublic void deleteBook(int id){bookDao.delete(Book.class, id);}}
9. 前台界面
bookForm.jsp

<%@ page contentType="text/html; charset=GBK" language="java" errorPage="" %><%@taglib prefix="s" uri="/struts-tags"%><!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml"><head><title>添加图书</title></head><body><h3>添加图书</h3><s:form action="addBook"><s:textfield name="book.name" label="书名"/><s:textfield name="book.price" label="价格"/><s:textfield name="book.author" label="作者"/><tr align="center"><td colspan="2"><s:submit value="添加" theme="simple"/><s:reset value="重设" theme="simple"/></td></tr></s:form></body></html>
listBooks.jsp

<%@ page contentType="text/html; charset=GBK" language="java" errorPage="" %><%@taglib prefix="s" uri="/struts-tags"%><!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml"><head><title>全部图书</title></head><body><h3>全部图书</h3><table width="640" border="1"><s:iterator value="books" var="b"><tr><td><s:property value="name"/></td><td><s:property value="price"/></td><td><s:property value="author"/></td><td><a href="${pageContext.request.contextPath}/deleteBook?id=${b.id}">删除</a></td></tr></s:iterator></table></body></html>
10.运行



数据库文件
/*Navicat MySQL Data TransferSource Server : defaultSource Server Version : 50626Source Host : localhost:3306Source Database : sampledbTarget Server Type : MYSQLTarget Server Version : 50626File Encoding : 65001Date: 2015-09-08 10:36:58*/SET FOREIGN_KEY_CHECKS=0;-- ------------------------------ Table structure for book_inf-- ----------------------------DROP TABLE IF EXISTS `book_inf`;CREATE TABLE `book_inf` (`book_id` int(11) NOT NULL AUTO_INCREMENT,`author` varchar(255) DEFAULT NULL,`book_name` varchar(255) DEFAULT NULL,`price` double NOT NULL,PRIMARY KEY (`book_id`)) ENGINE=InnoDB DEFAULT CHARSET=utf8;-- ------------------------------ Records of book_inf-- ------------------------------ ------------------------------ Table structure for t_login_log-- ----------------------------DROP TABLE IF EXISTS `t_login_log`;CREATE TABLE `t_login_log` (`login_log_id` int(11) NOT NULL AUTO_INCREMENT,`user_id` int(11) DEFAULT NULL,`ip` varchar(23) DEFAULT NULL,`login_datetime` datetime DEFAULT NULL,PRIMARY KEY (`login_log_id`)) ENGINE=InnoDB DEFAULT CHARSET=utf8;-- ------------------------------ Records of t_login_log-- ------------------------------ ------------------------------ Table structure for t_user-- ----------------------------DROP TABLE IF EXISTS `t_user`;CREATE TABLE `t_user` (`user_id` int(11) NOT NULL AUTO_INCREMENT,`user_name` varchar(30) DEFAULT NULL COMMENT '用户名',`credits` int(11) DEFAULT NULL,`password` varchar(32) DEFAULT NULL,`last_visit` datetime DEFAULT NULL,`last_ip` varchar(23) DEFAULT NULL,PRIMARY KEY (`user_id`)) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8;-- ------------------------------ Records of t_user-- ----------------------------INSERT INTO `t_user` VALUES ('1', 'admin', null, '123456', null, null);INSERT INTO `t_user` VALUES ('2', 'zpp', null, '888888', null, null);
附件列表
【Spring实战-3】Spring整合Hibernate、Struts的更多相关文章
- 【Spring实战】Spring注解配置工作原理源码解析
一.背景知识 在[Spring实战]Spring容器初始化完成后执行初始化数据方法一文中说要分析其实现原理,于是就从源码中寻找答案,看源码容易跑偏,因此应当有个主线,或者带着问题.目标去看,这样才能最 ...
- 【Spring实战】Spring容器初始化完成后执行初始化数据方法
一.背景知识及需求 在做WEB项目时,经常在项目第一次启动时利用WEB容器的监听.Servlet加载初始化等切入点为数据库准备数据,这些初始化数据是系统开始运行前必须的数据,例如权限组.系统选项.默认 ...
- 【转】【Spring实战】Spring注解配置工作原理源码解析
一.背景知识 在[Spring实战]Spring容器初始化完成后执行初始化数据方法一文中说要分析其实现原理,于是就从源码中寻找答案,看源码容易跑偏,因此应当有个主线,或者带着问题.目标去看,这样才能最 ...
- (一)《Spring实战》——Spring核心
<Spring实战>(第4版) 第一章:Spring之旅 1. 简化Java开发 为了降低Java开发的复杂性,Spring采取了以下4种关键策略: 基于POJO的轻量级和最小侵入性编程: ...
- Spring 学习笔记之整合Hibernate
Spring和Hibernate处于不同的层次,Spring关心的是业务逻辑之间的组合关系,Spring提供了对他们的强大的管理能力, 而Hibernate完成了OR的映射,使开发人员不用再去关心SQ ...
- Spring学习笔记之整合hibernate
1.web.xml里边要配置好对应的springxml的路径 <context-param> <param-name>contextConfigLocation</par ...
- (二)《Spring实战》——Spring核心
第二章:装配Bean 在Spring中,对象无需自己查找或创建与其所关联的其他对象.相反,容器负责把需要相互协作的对象引用赋予各个对象.例如,一个订单管理组件需要信用卡认证组件,但它不需要自己创建信用 ...
- 【Spring实战】----开篇(包含系列目录链接)
[Spring实战]----开篇(包含系列目录链接) 置顶2016年11月10日 11:12:56 阅读数:3617 终于还是要对Spring进行解剖,接下来Spring实战篇系列会以应用了Sprin ...
- spring MVC(十)---spring MVC整合mybatis
spring mvc可以通过整合hibernate来实现与数据库的数据交互,也可以通过mybatis来实现,这篇文章是总结一下怎么在springmvc中整合mybatis. 首先mybatis需要用到 ...
随机推荐
- Mysql 时间类型整理
一.date_sub.SUBDATE.date_add select now(), date_sub(now(),interval 1 minute),SUBDATE(now(),interval ...
- EhLib 的 DbgridEh 影响 其他数据集的Open方法
DbgridEh 对应数据集ADOTable1,其中有个字段 部门编码,另外增加查找字段比如 部门名称 ADOTable2对应查找数据集,包含 部门编码和 部门名称字段. ADOTable1 打开后, ...
- MyEclipse WebSphere开发教程:WebSphere 7安装指南(三)
[周年庆]MyEclipse个人授权 折扣低至冰点!立即开抢>> [MyEclipse最新版下载] 五.应用WebSphere 7.0.0.x和Java SDK更新 1. 要应用这些PAK ...
- TP使用易错知识点
1. redirect(U('Index/index')); //redirect函数跳转要使用U方法,不适用U方法会跳转地址出错. 2. $this->success('新增成功' ...
- 使用 Git & Repo 下载代码
客户端安装 Git 安装 git,gitk 网络连接正常的情况下: $ sudo apt-get install git-core gitk git-gui 不能上网,有.deb安装包的,请执行: $ ...
- chrome flash插件地址
C:\Users\Administrator\AppData\Local\Google\Chrome\User Data\PepperFlash 火狐
- HDU 1518 Square(DFS)
Problem Description Given a set of sticks of various lengths, is it possible to join them end-to-end ...
- python3 线性同余发生器 ( random 随机数生成器 ) 伪随机数产生周期的一些探究
import random x=[str(random.randint(0, 5)) for i in range(10)] x_str=''.join(x) y=[str(random.randin ...
- Python高手之路 ------读书有感
最近忙中偷闲把前些年买的<Python高手之路>翻了出来,大致看完了一遍,其中很多内容并不理解,究其原因应该是实践中的经验不足,而这对于现如今的我仍是难以克服的事情,对此也就只能说是看会了 ...
- 【c++基础】多个txt文件合并到一个文件的几种方式
参考 1.windows命令: 2.linux-command; 完