飞算JavaAI的安装及其使用方法

飞算JavaAI的安装及其使用方法

标签#JavaAI

首先,我i们先去电脑端自带的浏览器下载IDEA

界面往下滑可以看到下载安装。

安装后软件会显示在桌面,如果没有安装在桌面快捷,可以在系统应用中查找。

启动IDEA,在顶部菜单栏进入 File -> Settings (Windows/Linux)或 IntelliJ IDEA -> Preferences (macOS),打开对话框。

在设置界面左侧选择 Plugins 选项,切换到插件市场。在顶部的搜索框中输入关键词“飞算”。

搜索”Calex-JavaAI“,将该插件安装到右侧使用栏。

在对话框内输入你想要生成代码的题目。这里我用”校园餐饮服务评价系统的设计与实现”为例,做出以下分析及实操过程。

一、需求分析与规划

(一)功能需求

此次开发的餐饮电商系统,对于用户而言,需要能够快速注册登录,维护个人信息,根据自身权限浏览、搜索菜品,下单支付,对已完成订单进行评价等操作;对于商家,要能入驻平台,提交资质并通过审核,维护店铺信息,管理菜品(包括分类、详情、价格、库存等),处理订单,回复用户评价等;同时平台还需具备数据统计分析功能,按时间、品类、商家等维度生成运营报表,以及消息通知功能,推送系统消息、订单状态变更提醒和评价回复通知等。

(二)核心模块

系统核心模块包括用户管理模块、商家管理模块、菜品管理模块、订单管理模块、评价管理模块、数据统计分析模块、消息通知模块、搜索模块和支付管理模块。

(三)技术选型

采用飞算 JavaAI 辅助进行代码生成,结合 Spring Boot 框架搭建系统基础架构,使用 MySQL 数据库存储各类数据,前端可选用 Vue.js 框架构建交互界面,利用 Redis 做缓存优化性能,集成常见的支付 SDK 以支持多种支付方式。

二、飞算 JavaAI 开发实录

(一)飞算 JavaAI 操作流程

1. 理解需求:将餐饮电商系统的需求拆解为 10 个关键点,包括用户管理、商家管理、菜品管理、订单管理、评价管理、评价回复管理、数据统计分析、消息通知、搜索、支付接口集成等功能需求,飞算 JavaAI 可按需求调整这些关键点。

2. 设计接口:基于需求,飞算 JavaAI 生成 9 个接口方案,涵盖用户管理(含角色区分和访问授权)、商家管理(入驻申请、资质审核等)、菜品管理(分类、详情等维护)、订单管理(创建、支付、状态跟踪等)、评价管理(用户评分评论及商家回复)、数据统计分析(多维度报表)、消息通知(系统消息、订单和评价回复提醒)、搜索管理(关键词、分类等查找)等,支持自定义优化。

3. 表结构设计:飞算 JavaAI 设计出 11 张数据库表结构,以商家表为例,包含 merchant_id(商家 ID,主键自增)、user_id(关联用户 ID)、shop_name(店铺名称)、logo_url(店铺 Logo 地址)、description(店铺简介)、category_id(所属分类 ID)、address(详细地址)、contact_phone(联系电话)、opening_time(营业时间)、latitude(纬度)、longitude(经度)、status(店铺状态)、create_by(创建人)、create_time(创建时间)、update_by(修改人)、update_time(修改时间)等字段,支持个性化调整,如图 3 所示。

这里注意:图里面红框部分在生成表格之前会有一个”自动生成表格“选项,勾选点击之后才能生成数据库表格

4. 核心处理逻辑生成:输出多项核心处理逻辑,如 “查询订单统计数据” 接口,入参包括 startTime(开始时间,必填)、endTime(结束时间,必填)、merchantId(商家 ID,可选)、categoryId(品类 ID,可选),处理逻辑先校验时间范围是否合法,不合法则返回对应错误结果,合法则根据时间范围和筛选条件获取订单数据并统计订单量、金额等信息后返回成功结果;还有 “查询用户增长趋势” 接口,入参为 startTime 和 endTime,校验时间范围后按日统计注册用户数并返回趋势数据等。

5. 基础设置与代码生成:在基础设置中,输入根包名com.feisuanyz、项目名称JavaProject、项目接口根路径/JavaProject,选择是否转换 Gradle 项目(都可以)、是否代码优化(都可以),然后点击 “开始生成”,飞算 JavaAI 会按模块(生成代码,生成速度还是很快的,很节省时间。

(二)代码片段展示

以下是部分核心模块的代码片段(飞算 JavaAI 生成后略作调整):

1. 用户管理模块(UserController.java)
package com.feisuanyz.controller; import com.feisuanyz.common.RestResult; import com.feisuanyz.entity.User; import com.feisuanyz.service.UserService; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.*; @RestController @RequestMapping("/JavaProject/user") public class UserController { @Autowired private UserService userService; @PostMapping("/register") public RestResult register(@RequestBody User user) { // 调用服务层进行用户注册 boolean result = userService.register(user); if (result) { return RestResult.success("注册成功"); } else { return RestResult.fail("注册失败,用户名可能已存在"); } } @PostMapping("/login") public RestResult login(@RequestBody User user) { // 调用服务层进行用户登录校验 User loginUser = userService.login(user.getUsername(), user.getPassword()); if (loginUser != null) { // 生成token等操作(此处省略,实际项目中需完善) return RestResult.success("登录成功", loginUser); } else { return RestResult.fail("登录失败,用户名或密码错误"); } } @GetMapping("/{userId}") public RestResult getUserInfo(@PathVariable Long userId) { User user = userService.getUserById(userId); if (user != null) { return RestResult.success("获取用户信息成功", user); } else { return RestResult.fail("用户不存在"); } } @PutMapping("/{userId}") public RestResult updateUserInfo(@PathVariable Long userId, @RequestBody User user) { user.setUserId(userId); boolean result = userService.updateUser(user); if (result) { return RestResult.success("更新用户信息成功"); } else { return RestResult.fail("更新用户信息失败"); } } @PutMapping("/{userId}/role") public RestResult updateUserRole(@PathVariable Long userId, @RequestParam Integer role) { boolean result = userService.updateUserRole(userId, role); if (result) { return RestResult.success("修改用户角色成功"); } else { return RestResult.fail("修改用户角色失败"); } } @PutMapping("/{userId}/status") public RestResult updateUserStatus(@PathVariable Long userId, @RequestParam Integer status) { boolean result = userService.updateUserStatus(userId, status); if (result) { return RestResult.success("禁用/启用用户账户成功"); } else { return RestResult.fail("禁用/启用用户账户失败"); } } }
2. 订单管理模块(OrderService.java 部分方法)
package com.feisuanyz.service; import com.feisuanyz.entity.Order; import com.feisuanyz.vo.OrderStatisticVO; import java.util.Date; import java.util.List; public interface OrderService { Order createOrder(Order order); boolean processPayment(Long orderId); Order trackOrderStatus(Long orderId); boolean cancelOrder(Long orderId); Order getOrderDetail(Long orderId); List<OrderStatisticVO> statisticOrder(Date startTime, Date endTime, Long merchantId, Long categoryId); }
3. 数据统计分析模块(DataAnalysisController.java)
package com.feisuanyz.controller; import com.feisuanyz.common.RestResult; import com.feisuanyz.service.DataAnalysisService; import com.feisuanyz.vo.OrderStatisticVO; import com.feisuanyz.vo.UserGrowthVO; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.format.annotation.DateTimeFormat; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.RestController; import java.util.Date; import java.util.List; @RestController @RequestMapping("/JavaProject/dataAnalysis") public class DataAnalysisController { @Autowired private DataAnalysisService dataAnalysisService; @GetMapping("/orderStatistic") public RestResult statisticOrder( @RequestParam @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss") Date startTime, @RequestParam @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss") Date endTime, @RequestParam(required = false) Long merchantId, @RequestParam(required = false) Long categoryId) { // 校验时间范围是否合法 if (startTime.after(endTime)) { return RestResult.fail("时间范围不合法"); } List<OrderStatisticVO> result = dataAnalysisService.statisticOrder(startTime, endTime, merchantId, categoryId); return RestResult.success("调用成功", result); } @GetMapping("/userGrowth") public RestResult getUserGrowthTrend( @RequestParam @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss") Date startTime, @RequestParam @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss") Date endTime) { // 校验时间范围是否合法 if (startTime.after(endTime)) { return RestResult.fail("时间范围不合法"); } List<UserGrowthVO> result = dataAnalysisService.getUserGrowthTrend(startTime, endTime); return RestResult.success("调用成功", result); } }

三、优化与调试心得

(一)遇到的问题及解决

  1. 生成代码调整:飞算 JavaAI 生成的部分实体类字段注释不够详细,在后续对接前端和团队协作时,需要手动补充完善注释,确保字段含义清晰。
  2. SQL 优化:在进行数据统计分析,尤其是按多维度统计大量订单数据时,初始生成的 SQL 语句执行效率较低。通过使用飞算 JavaAI 的智能会话功能,咨询优化 SQL 的方法,结合索引优化和 SQL 语句重构,提升了查询性能。例如,为订单表的create_timemerchant_idcategory_id等字段添加联合索引,优化统计查询 SQL。
  3. 支付接口集成:生成的支付管理模块代码,在对接具体支付 SDK 时,存在一些参数传递和回调处理的细节问题。通过查阅支付 SDK 官方文档,并利用飞算 JavaAI 的智能引导,逐步调整代码,完成了多种支付方式的接入和交易记录管理。

(二)飞算 JavaAI 其他功能的利用

在遇到问题时,除了智能会话功能,还尝试使用其工具箱中的代码检查工具,对生成的代码进行静态检查,提前发现潜在的代码质量问题,如空指针风险、不规范的命名等,并进行修复。

四、效果展示与总结

(一)效果展示

工程结构图:生成的工程结构清晰,按模块划分,各模块下包含 controller、service、dao、entity、vo 等包,便于代码维护和扩展。

JavaProject ├── src │ ├── main │ │ ├── java │ │ │ ├── com │ │ │ │ ├── feisuanyz │ │ │ │ │ ├── controller │ │ │ │ │ │ ├── UserController.java │ │ │ │ │ │ ├── MerchantController.java │ │ │ │ │ │ ├── DishController.java │ │ │ │ │ │ ├── OrderController.java │ │ │ │ │ │ ├── EvaluationController.java │ │ │ │ │ │ ├── DataAnalysisController.java │ │ │ │ │ │ ├── MessageController.java │ │ │ │ │ │ ├── SearchController.java │ │ │ │ │ │ └── PaymentController.java │ │ │ │ │ ├── service │ │ │ │ │ │ ├── UserService.java │ │ │ │ │ │ ├── MerchantService.java │ │ │ │ │ │ ├── DishService.java │ │ │ │ │ │ ├── OrderService.java │ │ │ │ │ │ ├── EvaluationService.java │ │ │ │ │ │ ├── DataAnalysisService.java │ │ │ │ │ │ ├── MessageService.java │ │ │ │ │ │ ├── SearchService.java │ │ │ │ │ │ └── PaymentService.java │ │ │ │ │ ├── dao │ │ │ │ │ │ ├── UserDao.java │ │ │ │ │ │ ├── MerchantDao.java │ │ │ │ │ │ ├── DishDao.java │ │ │ │ │ │ ├── OrderDao.java │ │ │ │ │ │ ├── EvaluationDao.java │ │ │ │ │ │ └── PaymentDao.java │ │ │ │ │ ├── entity │ │ │ │ │ │ ├── User.java │ │ │ │ │ │ ├── Merchant.java │ │ │ │ │ │ ├── Dish.java │ │ │ │ │ │ ├── Order.java │ │ │ │ │ │ ├── Evaluation.java │ │ │ │ │ │ ├── Message.java │ │ │ │ │ │ └── PaymentRecord.java │ │ │ │ │ ├── vo │ │ │ │ │ │ ├── OrderStatisticVO.java │ │ │ │ │ │ ├── UserGrowthVO.java │ │ │ │ │ │ └── MerchantVO.java │ │ │ │ │ └── common │ │ │ │ │ ├── RestResult.java │ │ │ │ │ └── ResultCode.java │ │ └── resources │ │ ├── application.yml │ │ └── mapper │ │ ├── UserMapper.xml │ │ ├── MerchantMapper.xml │ │ ├── DishMapper.xml │ │ ├── OrderMapper.xml │ │ └── EvaluationMapper.xml

(二)飞算 JavaAI 的优势

1.高效性:能够快速将需求转化为接口设计、表结构设计和核心代码,极大缩短了开发周期,让开发者可以将更多精力放在业务逻辑优化和细节处理上。

2.便捷性:提供了从需求分析到代码生成的一站式服务,操作流程清晰,界面友好,降低了开发门槛,即使是经验相对不足的开发者也能快速上手进行项目开发。

3.智能辅助:智能会话、智能引导等功能,在开发过程中遇到问题时能及时提供帮助,辅助解决代码调整、SQL 优化等问题。

(三)不足与个人体会

1. 不足:生成的代码在一些细节处理上还不够完善,如部分异常处理不够全面,需要开发者手动补充;对于一些复杂的业务场景,生成的代码可能需要一定幅度的调整才能完全符合需求。

2. 个人体会:飞算 JavaAI 是一款非常有潜力的开发辅助工具,它改变了传统的开发模式,提高了开发效率,但它并不能完全替代开发者,开发者仍需具备扎实的编程基础和业务理解能力,以便对生成的代码进行调整和优化,充分发挥工具的价值。在未来的开发工作中,会继续探索飞算 JavaAI 的更多功能,结合自身技术能力,打造更优质的软件产品。

Read more

实战篇:Python开发monogod数据库mcp server看完你就会了

实战篇:Python开发monogod数据库mcp server看完你就会了

原创不易,请关注公众号:【爬虫与大模型开发】,大模型的应用开发之路,整理了大模型在现在的企业级应用的实操及大家需要注意的一些AI开发的知识点!持续输出爬虫与大模型的相关文章。 前言 目前mcp协议是给deepseek大模型插上工具链的翅膀,让大模型不仅拥有超高的推理和文本生成能力,还能具备执行大脑意识的工具能力! 如何开发一个mcp? mcp是一种协议,指的是模型上下文协议 (Model Context Protocol)。 官方结成的mcp https://github.com/modelcontextprotocol/python-sdk mcp库 pip install mcp from mcp.server.fastmcp import FastMCP 我们先来做一个简单的案例 from mcp.server.fastmcp import FastMCP import requests mcp = FastMCP("spider") @mcp.tool() def crawl(

By Ne0inhk
【大模型实战篇】基于Claude MCP协议的智能体落地示例

【大模型实战篇】基于Claude MCP协议的智能体落地示例

1. 背景         之前我们在《MCP(Model Context Protocol) 大模型智能体第一个开源标准协议》一文中,介绍了MCP的概念,虽然了解了其概念、架构、解决的问题,但还缺少具体的示例,来帮助进一步理解整套MCP框架如何落地。         今天我们基于claude的官方例子--获取天气预报【1】,来理解MCP落地的整条链路。 2. MCP示例         该案例是构建一个简单的MCP天气预报服务器,并将其连接到主机,即Claude for Desktop。从基本设置开始,然后逐步发展到更复杂的使用场景。         大模型虽然能力非常强,但其弊端就是内容是过时的,这里的过时不是说内容很旧,只是表达内容具有非实时性。比如没有获取天气预报和严重天气警报的能力。因此我们将使用MCP来解决这一问题。         构建一个服务器,该服务器提供两个工具:获取警报(get-alerts)和获取预报(get-forecast)。然后,将该服务器连接到MCP主机(在本例中为Claude for Desktop)。         首先我们配置下环

By Ne0inhk
AI Agent新范式:FastGPT+MCP协议实现工具增强型智能体构建

AI Agent新范式:FastGPT+MCP协议实现工具增强型智能体构建

AI Agent新范式:FastGPT+MCP协议实现工具增强型智能体构建 作者:高瑞冬 本文目录 * AI Agent新范式:FastGPT+MCP协议实现工具增强型智能体构建 * 一、MCP协议简介 * 二、创建MCP工具集 * 1. 获取MCP服务地址 * 2. 在FastGPT中创建MCP工具集 * 三、测试MCP工具 * 四、AI模型调用MCP工具 * 1. 调用单个工具 * 2. 调用整个工具集 * 五、私有化部署支持 * 1. 环境准备 * 2. 修改docker-compose.yml文件 * 3. 修改FastGPT配置 * 4. 重启服务 * 六、使用MCP-Proxy集成多个MCP服务 * 1. MCP-Proxy简介 * 2. 安装MCP-Proxy * 3. 配置MCP-Proxy * 4. 将MCP-Proxy与FastGPT集成 * 5. 高级配置

By Ne0inhk
AI革命先锋:DeepSeek与蓝耘通义万相2.1的无缝融合引领行业智能化变革

AI革命先锋:DeepSeek与蓝耘通义万相2.1的无缝融合引领行业智能化变革

云边有个稻草人-ZEEKLOG博客 目录 引言 一、什么是DeepSeek? 1.1 DeepSeek平台概述 1.2 DeepSeek的核心功能与技术 二、蓝耘通义万相2.1概述 2.1 蓝耘科技简介 2.2 蓝耘通义万相2.1的功能与优势 1. 全链条智能化解决方案 2. 强大的数据处理能力 3. 高效的模型训练与优化 4. 自动化推理与部署 5. 行业专用解决方案 三、蓝耘通义万相2.1与DeepSeek的对比分析 3.1 核心区别 3.2 结合使用的优势 四、蓝耘注册流程 五、DeepSeek与蓝耘通义万相2.1的集成应用 5.1 集成应用场景 1. 智能医疗诊断

By Ne0inhk