学习 jForum笔记 二 ForumAction

本文深入探讨了安道森练功房2.2.1版本中论坛分类与板块加载的过程,解析了如何从数据库加载板块并按分类进行组织,同时讨论了缓存使用方式以及分类与用户权限的关系。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

我的源程序是安道森练功房http://www.andowson.com/的2.2.1版本

2010.12.5接周五,继续研究。

Java代码 复制代码  收藏代码
  1. private void loadForums(ForumDAO fm) //取板块  
  2. {   
  3.     List<Forum> list = fm.selectAll(); //从数据表读取所有板块  
  4.        
  5.     Map<String, String> m = (Map<String, String>)cache.get(FQN, RELATION); //读缓存板块分类关系表  
  6.     if (m == null) { //缓存中没有  
  7.         m = new HashMap<String, String>();   
  8.     }   
  9.        
  10.     int lastId = 0;   //分类ID初值  
  11.     Category category = null;   
  12.     String catId = null;   
  13.   
  14.     for (Iterator<Forum> iter = list.iterator(); iter.hasNext(); ) {   
  15.         Forum forum = iter.next();   
  16.            
  17.         if (forum.getCategoryId() != lastId) {  //不属于当前分类  
  18.             if (category != null) {   
  19.                 cache.add(FQN, catId, category); //将所属分类写入缓存  
  20.             }   
  21.                
  22.             lastId = forum.getCategoryId();  //设置当前分类ID  
  23.             catId = Integer.toString(forum.getCategoryId());   
  24.             category = (Category)cache.get(FQN, catId); //读缓存中有无当前分类实体  
  25.         }   
  26.            
  27.         if (category == null) { //前面已将所有分类读入缓存,所以如果缓存中没有则数据表中也没有对应分类,如对应的分类不存在则报错。  
  28.             throw new CategoryNotFoundException("Category for forum #" + forum.getId() + " not found");   
  29.         }   
  30.            
  31.         String forumId = Integer.toString(forum.getId());   
  32.         category.addForum(forum); //将板块加入分类  
  33.         m.put(forumId, catId); //M的格式是板块ID,分类ID  
  34.     }   
  35.        
  36.     if (category != null) {   
  37.         cache.add(FQN, catId, category);   //将分类写入缓存  
  38.     }   
  39.        
  40.     cache.add(FQN, RELATION, m);  //将板块分类关系表写入缓存  
  41. }  
	private void loadForums(ForumDAO fm) //取板块
	{
		List<Forum> list = fm.selectAll(); //从数据表读取所有板块
		
		Map<String, String> m = (Map<String, String>)cache.get(FQN, RELATION); //读缓存板块分类关系表
		if (m == null) { //缓存中没有
			m = new HashMap<String, String>();
		}
		
		int lastId = 0;   //分类ID初值
		Category category = null;
		String catId = null;

		for (Iterator<Forum> iter = list.iterator(); iter.hasNext(); ) {
			Forum forum = iter.next();
			
			if (forum.getCategoryId() != lastId) {  //不属于当前分类
				if (category != null) {
					cache.add(FQN, catId, category); //将所属分类写入缓存
				}
				
				lastId = forum.getCategoryId();  //设置当前分类ID
				catId = Integer.toString(forum.getCategoryId());
				category = (Category)cache.get(FQN, catId); //读缓存中有无当前分类实体
			}
			
			if (category == null) { //前面已将所有分类读入缓存,所以如果缓存中没有则数据表中也没有对应分类,如对应的分类不存在则报错。
				throw new CategoryNotFoundException("Category for forum #" + forum.getId() + " not found");
			}
			
			String forumId = Integer.toString(forum.getId());
			category.addForum(forum); //将板块加入分类
			m.put(forumId, catId); //M的格式是板块ID,分类ID
		}
		
		if (category != null) {
			cache.add(FQN, catId, category);   //将分类写入缓存
		}
		
		cache.add(FQN, RELATION, m);  //将板块分类关系表写入缓存
	}
 

我又看了一下category.addForum(forum)过程,

Java代码 复制代码  收藏代码
  1. public void addForum(Forum forum) {   
  2.     this.forumsIdMap.put(Integer.valueOf(forum.getId()), forum);  //写入板块ID映射  
  3.     this.forums.add(forum); //写入板块集合  
  4. }  
	public void addForum(Forum forum) {
		this.forumsIdMap.put(Integer.valueOf(forum.getId()), forum);  //写入板块ID映射
		this.forums.add(forum); //写入板块集合
	}

 却意外发现,在category创建的时候已经读入了所有的forum,那为什么在forumRepository的start中又再次读一遍呢?有些奇怪,水平有限,不太明白。

Java代码 复制代码  收藏代码
  1. public Category(Category category) {   
  2.     this.name = category.getName();   
  3.     this.id = category.getId();   
  4.     this.order = category.getOrder();   
  5.     this.moderated = category.isModerated();   
  6.        
  7.     for (Iterator<Forum> iter = category.getForums().iterator(); iter.hasNext(); ) {   
  8.         Forum forum = new Forum(iter.next());    
  9.         this.forumsIdMap.put(Integer.valueOf(forum.getId()), forum);//写入板块ID映射  
  10.         this.forums.add(forum); //写入板块集合  
  11.     } //读入所有的板块,写入板块集合和板块ID映射   
  12. }  
	public Category(Category category) {
		this.name = category.getName();
		this.id = category.getId();
		this.order = category.getOrder();
		this.moderated = category.isModerated();
		
		for (Iterator<Forum> iter = category.getForums().iterator(); iter.hasNext(); ) {
			Forum forum = new Forum(iter.next()); 
			this.forumsIdMap.put(Integer.valueOf(forum.getId()), forum);//写入板块ID映射
			this.forums.add(forum); //写入板块集合
		} //读入所有的板块,写入板块集合和板块ID映射
	}

 category.getForums()是读取分类下的当前用户有权处理的所有板块,但让我有些困惑的是,其来源是this.forums。而调用这个过程的Category又是将处理后的结果写入this.forums。难道说,是做一个过滤?将用户无权处理的板块删除出this.forums?

Java代码 复制代码  收藏代码
  1. public Collection<Forum> getForums()   
  2. {   
  3.     if (this.forums.size() == 0) { //如果没有,直接返回空  
  4.         return this.forums;   
  5.     }   
  6.        //否则,返回有权处理的板块   
  7.     return this.getForums(SessionFacade.getUserSession().getUserId());   
  8. }  
	public Collection<Forum> getForums()
	{
		if (this.forums.size() == 0) { //如果没有,直接返回空
			return this.forums;
		}
        //否则,返回有权处理的板块
		return this.getForums(SessionFacade.getUserSession().getUserId());
	}
 
Java代码 复制代码  收藏代码
  1. public Collection<Forum> getForums(int userId)  //根据用户ID返回有权处理的板块  
  2. {   
  3.     PermissionControl pc = SecurityRepository.get(userId); //板限控制  
  4.     List<Forum> forums = new ArrayList<Forum>();   
  5.   
  6.     for (Iterator<Forum> iter = this.forums.iterator(); iter.hasNext(); ) {   
  7.         Forum forum = iter.next();   
  8.         if (pc.canAccess(SecurityConstants.PERM_FORUM, Integer.toString(forum.getId()))) {   
  9.             forums.add(forum); //如果有权控制板块,则添加到返回列表  
  10.         }   
  11.     }   
  12.        
  13.     return forums;   
内容概要:本文深入解析了扣子COZE AI编程及其详细应用代码案例,旨在帮助读者理解新一代低门槛智能体开发范式。文章从五个维度展开:关键概念、核心技巧、典型应用场景、详细代码案例分析以及未来发展趋势。首先介绍了扣子COZE的核心概念,如Bot、Workflow、Plugin、Memory和Knowledge。接着分享了意图识别、函数调用链、动态Prompt、渐进式发布及监控可观测等核心技巧。然后列举了企业内部智能客服、电商导购助手、教育领域AI助教和金融行业合规质检等应用场景。最后,通过构建“会议纪要智能助手”的详细代码案例,展示了从需求描述、技术方案、Workflow节点拆解到调试与上线的全过程,并展望了多智能体协作、本地私有部署、Agent2Agent协议、边缘计算插件和实时RAG等未来发展方向。; 适合人群:对AI编程感兴趣的开发者,尤其是希望快速落地AI产品的技术人员。; 使用场景及目标:①学习如何使用扣子COZE构建生产级智能体;②掌握智能体实例、自动化流程、扩展能力和知识库的使用方法;③通过实际案例理解如何实现会议纪要智能助手的功能,包括触发器设置、下载节点、LLM节点Prompt设计、Code节点处理和邮件节点配置。; 阅读建议:本文不仅提供了理论知识,还包含了详细的代码案例,建议读者结合实际业务需求进行实践,逐步掌握扣子COZE的各项功能,并关注其未来的发展趋势。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值