SSH整合小项目 简单的登陆注册

准备

所需架包
这里写图片描述

web.xml

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" id="WebApp_ID" version="3.0">
  <display-name>FirstSSH</display-name> 
  <!-- 启动Spring -->
  <listener>
    <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
  </listener>
  <!-- 配置文件名 -->
  <context-param>
    <param-name>contextConfigLocation</param-name>
    <param-value>classpath:applicationContext.xml</param-value>
  </context-param>

  <!-- struts核心过滤器 -->
  <filter>
    <filter-name>struts</filter-name>
    <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
  </filter>
  <filter-mapping>
    <filter-name>struts</filter-name>
    <url-pattern>/*</url-pattern>
  </filter-mapping>
</web-app>

前端代码

前端网页
准备 success.jsperror.jsp

login.jsp
<body>
    <form action="UserAction_login">
        <label>用户名:</label>
        <input name="name"/>
        <label>密码:</label>
        <input name="password"/>
        <input type="submit" value="登录"/>
    </form>
</body>
register.jsp
<body>
    <form method="post" action="UserAction_register">
        用户名:<input type="text" name="name"><br>
        密码:<input type="password" name="password"><br>
        <input type="submit" value="提交">
    </form>
</body>

后台代码

UserAction.java

@Scope("prototype")
@Controller("userAction")
public class UserAction extends ActionSupport implements ModelDriven<User>{

    @Autowired
    UserService userService;

    private User u;

    //登录请求
    public String login(){
        if (userService.loginUser(u.getName(), u.getPassword())) {
            return SUCCESS;
        }
        //调用service判断是否登录成功
        return ERROR;
    }

    public String register(){
        userService.register(u);
        return SUCCESS;
    }

    @Override
    public User getModel() {
        u = new User();
        return u;
    }
}

实体类和映射XML文件跳过
UserServiceImpl.java

@Service("userService")
public class UserServiceImpl implements UserService{

    @Autowired
    private UserDao userDao;

    @Override
    public boolean loginUser(String username, String password) {
        User u = userDao.loginUser(username, password);
        if (u != null) {
            return true;
        }
        return false;
    }

    @Override
    public void register(User u) {
        userDao.register(u);
    }

}

UserDaoImpl.java

@Transactional
@Repository("userDao")
public class UserDaoImpl extends HibernateDaoSupport implements UserDao{

    @Override
    public User loginUser(String username, String password) {
        return getHibernateTemplate().execute(new HibernateCallback<User>() {
            @Override
            public User doInHibernate(Session session) throws HibernateException {
                Query query = session.createQuery("from User where name = ? and password = ?");
                query.setParameter(0, username);
                query.setParameter(1, password);
                User user = (User) query.uniqueResult();
                return user;
            }
        });
    }

    @Override
    public void register(User u) {
        getHibernateTemplate().save(u);
    }
}

applicationContext.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"
    xmlns:context="http://www.springframework.org/schema/context"
    xmlns:tx="http://www.springframework.org/schema/tx"
    xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
        http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.3.xsd
        http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-4.3.xsd">

<bean name="sessionFactory"
        class="org.springframework.orm.hibernate5.LocalSessionFactoryBean">
        <!-- 该属性用来设置JDBC相关参数 -->
        <property name="hibernateProperties">
            <props>
                <prop key="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</prop>
                <!-- 可选 -->
                <prop key="hibernate.show_sql">true</prop>
                <prop key="hibernate.format_sql">true</prop>
                <prop key="hibernate.hbm2ddl.auto">update</prop>
            </props>
        </property>
        <!-- 指定映射文件的路径 -->
        <property name="mappingDirectoryLocations" value="classpath:com/lanou/bean"></property>
        <!-- 指定连接池 -->
        <property name="dataSource" ref="dataSource"></property>
    </bean>

    <bean name="userDao" class="com.lanou.daoImpl.UserDaoImpl">
        <property name="sessionFactory" ref="sessionFactory">
        </property>
    </bean>

    <!-- 加载properties文件 -->
    <context:property-placeholder location="classpath:db.properties"/>


    <!-- Spring配置事务 四步骤 -->
    <!-- 1.提供连接池 -->
    <bean name="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
        <property name="driverClass" value="${driverClass}"></property>
        <property name="jdbcUrl" value="${jdbcUrl}"></property>
        <!-- ${user} 会获取电脑账户名  所以不能叫user-->
        <property name="user" value="${userName}"></property>
        <property name="password" value="${password}"></property>
    </bean>
    <!-- 2.创建事务管理对象 -->
    <bean name="transactionManager" class="org.springframework.orm.hibernate5.HibernateTransactionManager">
        <!-- 注入会话工厂 -->
        <property name="sessionFactory" ref="sessionFactory"></property>
    </bean>

    <!-- 3.启动AOP事务注解 -->
    <tx:annotation-driven/>

    <!-- 开启注解扫描 -->
    <context:component-scan base-package="com.lanou"></context:component-scan>

</beans>

db.properties
driverClass=com.mysql.jdbc.Driver
jdbcUrl=jdbc:mysql:///myjdbc
userName=root
password=123456

struts.xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts PUBLIC
    "-//Apache Software Foundation//DTD Struts Configuration 2.3//EN"
    "http://struts.apache.org/dtds/struts-2.3.dtd">

<struts>
    <package name="user" extends="struts-default" namespace="/">
        <action name="UserAction_*" method="{1}" class="userAction">
            <result name="success">/index.jsp</result>
            <result name="error">/error.jsp</result>
        </action>
    </package>
</struts>

! 注意细节 !

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在SSH整合MongoDB,您需要按照以下步骤操作: 1. 首先,确保您已经在服务器上安装了SSH服务和MongoDB。如果您还没有安装MongoDB,请先按照官方文档进行安装。 2. 使用SSH客户端连接到您的服务器。您可以使用命令行工具(如OpenSSH)或图形界面工具(如PuTTY)进行连接。 3. 在服务器上创建一个新的MongoDB数据库用户,以便您可以通过SSH连接进行管理。可以使用以下命令创建用户,并为其分配适当的角色和访问权限: ``` use admin db.createUser({ user: "your-username", pwd: "your-password", roles: [{ role: "root", db: "admin" }] }) ``` 替换`your-username`和`your-password`为您希望使用的用户名和密码。 4. 进行SSH隧道设置,将本地端口与远程MongoDB服务器端口进行映射。使用以下命令: ``` ssh -L local-port:localhost:remote-port your-username@your-server-ip ``` 替换`local-port`为您本地计算机上的空闲端口号,`remote-port`为远程MongoDB服务器上的MongoDB端口,默认为27017。`your-username`和`your-server-ip`根据您的实际情况进行替换。 5. 打开新的终端窗口,并使用以下命令连接到本地端口: ``` mongo --host localhost --port local-port -u your-username -p your-password --authenticationDatabase admin ``` 替换`local-port`与步骤4中使用的本地端口号,`your-username`和`your-password`为您在步骤3中创建的MongoDB数据库用户的凭据。 现在,您应该能够通过SSH连接到MongoDB并进行管理操作。请注意,此方法仅在本地计算机上建立了一个安全的通信通道,以便通过SSH访问远程MongoDB服务器。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值