新网创想网站建设,新征程启航
为企业提供网站建设、域名注册、服务器等服务
本篇内容介绍了“cppweb怎么从零开始新建一个java应用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
创新互联建站成立于2013年,我们提供高端成都网站建设、网站制作公司、成都网站设计、网站定制、网络营销推广、微信小程序、微信公众号开发、营销推广服务,提供专业营销思路、内容策划、视觉设计、程序开发来完成项目落地,为混凝土搅拌罐车企业提供源源不断的流量和订单咨询。
如果系统安装了java开发环境(需要设置JAVA_HOME环境变量),在初始化cppweb编译环境时会启用java编译选项。cppweb源码文件中有一个java工程示例,工程目录路径为$SOURCE_HOME/webapp/jar
,目录结构如下:
bin:编译输出目录 src:工程源码目录
工程中有一个简单的应用源码文件$SOURCE_HOME/webapp/jar/src/app
,源码内容如下:
package app;import webx.WebApp;import stdx.Required;import stdx.Optional;import webx.utils.DBConnect;import webx.http.HttpRequest;import webx.http.HttpResponse;class Request{@Required("用户ID")public String user;@Optional("用户姓名")public String name; }class Response{@Required("错误码")public int code;@Optional("错误描述")public String desc; }@WebApp.Path(value = "${filename}", access = "public")@WebApp.Document(request = Request.class, response = Response.class, remark = "JAVA示例接口")public class JavaTest extends WebApp{public void process(HttpRequest request, HttpResponse response) throws Exception{ Long msg = DBConnect.Select(Long.class, "SELECT ?", System.currentTimeMillis()); response.setBody(String.valueOf(msg)); } }
上述源码文件中有两个关键注解,注解说明如下:
WebApp.Path
应用路径注解,该注解有两个属性,value
属性代表最终映射的接口路径,access
表示接口的访问权限(有public、protect、private等取值)。
WebApp.Document
接口文档声明注解,request
为请求类的元数据对象,response
为响应类的元数据对象,remark
为接口名称说明,以该注解标记的应用会生成接口文档,访问http://localhost:8888/app/workspace/pub/apidoc.htm
地址可查看接口文档。
修改源码后,进入$SOURCE_HOME/webapp/jar
目录执行make
命令可编译生成应用对应的字节码文件,编译完成后重启webserver访问javatest
地址可以查看应用执行效果,WebApp.Path
注解的value
属性值${filename}
会替换成具体类名的英文小写(此处为javatest
)。
在实际开发过程中,一般用集成开发环境开发web应用,在使用集成开发环境编译cppweb应用时需要包含$SOURCE_HOME/product/jar
目录下的所有jar包,如果是windows系统我们建议设置$SOURCE_HOME
环境变量。下图是我们idea工程配置:
如果需要在idea中运行或调试webserver服务,需要注释掉启动配置文件$SOURCE_HOME/webapp/etc/config.lua
中的JAVA_CLASSPATH
配置项,idea工程的启动类固定为webx.WebApp
(对应的源码文件为$SOURCE_HOME/library/java/webx/WebApp.java
)。
“cppweb怎么从零开始新建一个java应用”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注创新互联网站,小编将为大家输出更多高质量的实用文章!