jforum二次开发相关笔记——(一)页面请求机制

2024-04-15 19:08

本文主要是介绍jforum二次开发相关笔记——(一)页面请求机制,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!



目录[-]

  • jforum二次开发相关笔记
  • 1. 引言
  • 2. jforum的页面请求机制
  • 2.1 处理url
  • 2.2 查询action
  • 2.3 查询dao层
  • 2.4 查询sql
  • 2.5 返回结果到页面
  • 2.6 打印页面
  • 5. 参考资料

jforum二次开发相关笔记


  1. 引言
  2. jforum页面请求机制
  3. 单点登录实现
  4. Cookie安全
  5. 参考资料

1. 引言

jforum是Rafael Steil开发的一个基于JAVA的开源论坛,采用BSD开源协议,可以最大限度的进行任何修改和扩展,包括商业用途。它提供了诸如SSO之类的抽象接口,具有完全的权限控制、支持包括中文在内的十几种语言、可自定义的用户接口、安全、多数据库支持等特性。JForum 采用 FreeMarker作为页面模板引擎。jforum的介绍这里不再敷述,因项目需要,需要对jforum进行修改、实现从CS平台登录以后单点登录到jforum,因为jforum只支持唯一用户名标识,所以还需对jforum进行二次开发。(注:本文的jforum版本为2.1.9。)

2. jforum的页面请求机制

将jforum导入到eclipse可以参考《Java开源论坛JForum二次开发技术资料之导入安装》。以最简单的在一个登陆用户进入个人资料页为例: jforum导航栏

2.1 处理url

用户点击个人资料,页面请求的url为/user/edit/session中获取的用户Id如header.htm源码所示:

/jforum/WebContent/templates/default/header.htm

<a id="myprofile" class="mainmenu" href="${JForumContext.encodeURL("/user/edit/${session.userId}")}">
<img src="${contextPath}/templates/${templateName}/images/icon_mini_profile.gif" border="0" alt="[Profile]" /> 
${I18n.getMessage("ForumBase.profile")}
</a>&nbsp;

JForum中的JForumContext.encodeURL方法(注:实现在/jforum/src/net/jforum/context/JForumContext.java下)根据请求的url中的useredit在modulesMapping.properties中查询user对应的配置项:

/jforum/WebContent/WEB-INF/config/modulesMapping.properties

user=net.jforum.view.forum.UserAction

2.2 查询action

根据请求的url中的edit在相应的UserAction中找到edit方法:

/jforum/src/net/jforum/view/forum/UserAction.java

public void edit() {if (this.canEdit()) {int userId = this.request.getIntParameter("user_id");UserDAO um = DataAccessDriver.getInstance().newUserDAO();User u = um.selectById(userId);this.context.put("u", u);this.context.put("action", "editSave");this.context.put("pageTitle",I18n.getMessage("UserProfile.profileFor") + " "    +u.getUsername());this.context.put("avatarAllowExternalUrl", SystemGlobals.getBoolValue(ConfigKeys.AVATAR_ALLOW_EXTERNAL_URL));this.setTemplateName(TemplateKeys.USER_EDIT);}
}

2.3 查询dao层

根据action中的um.selectById(userId)请求UserDAO文件中的selectById方法:

/jforum/src/net/jforum/dao/UserDAO.java

    /*** Gets a specific <code>User</code>.* * @param userId The User ID to search* @return <code>User</code>object containing all the information* @see #selectAll*/public User selectById(int userId) ;

UserDAO只是一个抽象的DAO接口,GenericUserDAO具体实现了UserDAO中定义的方法:

/jforum/src/net/jforum/dao/generic/GenericUserDAO.java

/*** @see net.jforum.dao.UserDAO#selectById(int)*/
public User selectById(int userId)
{String q = SystemGlobals.getSql("UserModel.selectById");PreparedStatement p = null;ResultSet rs = null;try {p = JForumExecutionContext.getConnection().prepareStatement(q);p.setInt(1, userId);rs = p.executeQuery();User u = new User();if (rs.next()) {this.fillUserFromResultSet(u, rs);u.setPrivateMessagesCount(rs.getInt("private_messages"));rs.close();p.close();// User groupsp = JForumExecutionContext.getConnection().prepareStatement(SystemGlobals.getSql("UserModel.selectGroups"));p.setInt(1, userId);rs = p.executeQuery();while (rs.next()) {Group g = new Group();g.setName(rs.getString("group_name"));g.setId(rs.getInt("group_id"));u.getGroupsList().add(g);}}return u;}catch (SQLException e) {throw new DatabaseException(e);}finally {DbUtils.close(rs, p);}
}

2.4 查询sql

根据GenericUserDAO文件中的UserModel.selectById查询sql文件中相应的sql:

/jforum/WebContent/WEB-INF/config/database/generic/generic_queries.sql

UserModel.selectById = SELECT COUNT(pm.privmsgs_to_userid) AS private_messages, u.* \FROM jforum_users u \LEFT JOIN jforum_privmsgs pm ON pm.privmsgs_type = 1 AND pm.privmsgs_to_userid = u.user_id \WHERE u.user_id = ? \GROUP BY pm.privmsgs_to_userid

2.5 返回结果到页面

根据templatesMapping中的配置找到user.edit对应的页面 /jforum/WebContent/WEB-INF/config/templatesMapping.properties

user.edit = user_form.htm

2.6 打印页面

在页面中填入查询到的值:

/jforum/WebContent/templates/default/user_form.htm

<span class="gen"><#if admin?default(false)><input class="post" type="text" name="username"  value="${u.username?html}" /><#else>${u.username?html}</#if>
</span>

用户的实体类在/jforum/src/net/jforum/entities/User.java下。 个人资料页如下图所示:

jforum个人资料页

目录[-]

  • jforum二次开发相关笔记
  • 1. 引言
  • 2. jforum的页面请求机制
  • 2.1 处理url
  • 2.2 查询action
  • 2.3 查询dao层
  • 2.4 查询sql
  • 2.5 返回结果到页面
  • 2.6 打印页面
  • 5. 参考资料

jforum二次开发相关笔记


  1. 引言
  2. jforum页面请求机制
  3. 单点登录实现
  4. Cookie安全
  5. 参考资料

1. 引言

jforum是Rafael Steil开发的一个基于JAVA的开源论坛,采用BSD开源协议,可以最大限度的进行任何修改和扩展,包括商业用途。它提供了诸如SSO之类的抽象接口,具有完全的权限控制、支持包括中文在内的十几种语言、可自定义的用户接口、安全、多数据库支持等特性。JForum 采用 FreeMarker作为页面模板引擎。jforum的介绍这里不再敷述,因项目需要,需要对jforum进行修改、实现从CS平台登录以后单点登录到jforum,因为jforum只支持唯一用户名标识,所以还需对jforum进行二次开发。(注:本文的jforum版本为2.1.9。)

2. jforum的页面请求机制

将jforum导入到eclipse可以参考《Java开源论坛JForum二次开发技术资料之导入安装》。以最简单的在一个登陆用户进入个人资料页为例: jforum导航栏

2.1 处理url

用户点击个人资料,页面请求的url为/user/edit/session中获取的用户Id如header.htm源码所示:

/jforum/WebContent/templates/default/header.htm

<a id="myprofile" class="mainmenu" href="${JForumContext.encodeURL("/user/edit/${session.userId}")}">
<img src="${contextPath}/templates/${templateName}/images/icon_mini_profile.gif" border="0" alt="[Profile]" /> 
${I18n.getMessage("ForumBase.profile")}
</a>&nbsp;

JForum中的JForumContext.encodeURL方法(注:实现在/jforum/src/net/jforum/context/JForumContext.java下)根据请求的url中的useredit在modulesMapping.properties中查询user对应的配置项:

/jforum/WebContent/WEB-INF/config/modulesMapping.properties

user=net.jforum.view.forum.UserAction

2.2 查询action

根据请求的url中的edit在相应的UserAction中找到edit方法:

/jforum/src/net/jforum/view/forum/UserAction.java

public void edit() {if (this.canEdit()) {int userId = this.request.getIntParameter("user_id");UserDAO um = DataAccessDriver.getInstance().newUserDAO();User u = um.selectById(userId);this.context.put("u", u);this.context.put("action", "editSave");this.context.put("pageTitle",I18n.getMessage("UserProfile.profileFor") + " "    +u.getUsername());this.context.put("avatarAllowExternalUrl", SystemGlobals.getBoolValue(ConfigKeys.AVATAR_ALLOW_EXTERNAL_URL));this.setTemplateName(TemplateKeys.USER_EDIT);}
}

2.3 查询dao层

根据action中的um.selectById(userId)请求UserDAO文件中的selectById方法:

/jforum/src/net/jforum/dao/UserDAO.java

    /*** Gets a specific <code>User</code>.* * @param userId The User ID to search* @return <code>User</code>object containing all the information* @see #selectAll*/public User selectById(int userId) ;

UserDAO只是一个抽象的DAO接口,GenericUserDAO具体实现了UserDAO中定义的方法:

/jforum/src/net/jforum/dao/generic/GenericUserDAO.java

/*** @see net.jforum.dao.UserDAO#selectById(int)*/
public User selectById(int userId)
{String q = SystemGlobals.getSql("UserModel.selectById");PreparedStatement p = null;ResultSet rs = null;try {p = JForumExecutionContext.getConnection().prepareStatement(q);p.setInt(1, userId);rs = p.executeQuery();User u = new User();if (rs.next()) {this.fillUserFromResultSet(u, rs);u.setPrivateMessagesCount(rs.getInt("private_messages"));rs.close();p.close();// User groupsp = JForumExecutionContext.getConnection().prepareStatement(SystemGlobals.getSql("UserModel.selectGroups"));p.setInt(1, userId);rs = p.executeQuery();while (rs.next()) {Group g = new Group();g.setName(rs.getString("group_name"));g.setId(rs.getInt("group_id"));u.getGroupsList().add(g);}}return u;}catch (SQLException e) {throw new DatabaseException(e);}finally {DbUtils.close(rs, p);}
}

2.4 查询sql

根据GenericUserDAO文件中的UserModel.selectById查询sql文件中相应的sql:

/jforum/WebContent/WEB-INF/config/database/generic/generic_queries.sql

UserModel.selectById = SELECT COUNT(pm.privmsgs_to_userid) AS private_messages, u.* \FROM jforum_users u \LEFT JOIN jforum_privmsgs pm ON pm.privmsgs_type = 1 AND pm.privmsgs_to_userid = u.user_id \WHERE u.user_id = ? \GROUP BY pm.privmsgs_to_userid

2.5 返回结果到页面

根据templatesMapping中的配置找到user.edit对应的页面 /jforum/WebContent/WEB-INF/config/templatesMapping.properties

user.edit = user_form.htm

2.6 打印页面

在页面中填入查询到的值:

/jforum/WebContent/templates/default/user_form.htm

<span class="gen"><#if admin?default(false)><input class="post" type="text" name="username"  value="${u.username?html}" /><#else>${u.username?html}</#if>
</span>

用户的实体类在/jforum/src/net/jforum/entities/User.java下。 个人资料页如下图所示:

jforum个人资料页

这篇关于jforum二次开发相关笔记——(一)页面请求机制的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/906671

相关文章

Android WebView无法加载H5页面的常见问题和解决方法

《AndroidWebView无法加载H5页面的常见问题和解决方法》AndroidWebView是一种视图组件,使得Android应用能够显示网页内容,它基于Chromium,具备现代浏览器的许多功... 目录1. WebView 简介2. 常见问题3. 网络权限设置4. 启用 JavaScript5. D

Flutter监听当前页面可见与隐藏状态的代码详解

《Flutter监听当前页面可见与隐藏状态的代码详解》文章介绍了如何在Flutter中使用路由观察者来监听应用进入前台或后台状态以及页面的显示和隐藏,并通过代码示例讲解的非常详细,需要的朋友可以参考下... flutter 可以监听 app 进入前台还是后台状态,也可以监听当http://www.cppcn

Qt实现发送HTTP请求的示例详解

《Qt实现发送HTTP请求的示例详解》这篇文章主要为大家详细介绍了如何通过Qt实现发送HTTP请求,文中的示例代码讲解详细,具有一定的借鉴价值,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1、添加network模块2、包含改头文件3、创建网络访问管理器4、创建接口5、创建网络请求对象6、创建一个回复对

Nginx之upstream被动式重试机制的实现

《Nginx之upstream被动式重试机制的实现》本文主要介绍了Nginx之upstream被动式重试机制的实现,可以通过proxy_next_upstream来自定义配置,具有一定的参考价值,感兴... 目录默认错误选择定义错误指令配置proxy_next_upstreamproxy_next_upst

MySQL表锁、页面锁和行锁的作用及其优缺点对比分析

《MySQL表锁、页面锁和行锁的作用及其优缺点对比分析》MySQL中的表锁、页面锁和行锁各有特点,适用于不同的场景,表锁锁定整个表,适用于批量操作和MyISAM存储引擎,页面锁锁定数据页,适用于旧版本... 目录1. 表锁(Table Lock)2. 页面锁(Page Lock)3. 行锁(Row Lock

SpringBoot项目注入 traceId 追踪整个请求的日志链路(过程详解)

《SpringBoot项目注入traceId追踪整个请求的日志链路(过程详解)》本文介绍了如何在单体SpringBoot项目中通过手动实现过滤器或拦截器来注入traceId,以追踪整个请求的日志链... SpringBoot项目注入 traceId 来追踪整个请求的日志链路,有了 traceId, 我们在排

禁止HTML页面滚动的操作方法

《禁止HTML页面滚动的操作方法》:本文主要介绍了三种禁止HTML页面滚动的方法:通过CSS的overflow属性、使用JavaScript的滚动事件监听器以及使用CSS的position:fixed属性,每种方法都有其适用场景和优缺点,详细内容请阅读本文,希望能对你有所帮助... 在前端开发中,禁止htm

如何使用Java实现请求deepseek

《如何使用Java实现请求deepseek》这篇文章主要为大家详细介绍了如何使用Java实现请求deepseek功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1.deepseek的api创建2.Java实现请求deepseek2.1 pom文件2.2 json转化文件2.2

Android 悬浮窗开发示例((动态权限请求 | 前台服务和通知 | 悬浮窗创建 )

《Android悬浮窗开发示例((动态权限请求|前台服务和通知|悬浮窗创建)》本文介绍了Android悬浮窗的实现效果,包括动态权限请求、前台服务和通知的使用,悬浮窗权限需要动态申请并引导... 目录一、悬浮窗 动态权限请求1、动态请求权限2、悬浮窗权限说明3、检查动态权限4、申请动态权限5、权限设置完毕后

如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别详解

《如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别详解》:本文主要介绍如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别的相关资料,描述了如何使用海康威视设备网络SD... 目录前言开发流程问题和解决方案dll库加载不到的问题老旧版本sdk不兼容的问题关键实现流程总结前言作为