当前位置:首页 » 编程语言 » java后台代码

java后台代码

发布时间: 2025-08-11 18:36:13

java后台如何一直运行一个后台

1,保证主线程阻塞,即在执行main方法里添加阻塞代码。

2,比如Java做服务器时,接收soket信息,

	
ServerSocketserverSocket=newServerSocket(10086);//1024-65535的某个端口
//2、调用accept()方法开始监听,等待客户端的连接
while(true){}
Socketsocket=serverSocket.accept();
//3、获取输入流,并读取客户端信息
InputStreamis=socket.getInputStream();
InputStreamReaderisr=newInputStreamReader(is);
BufferedReaderbr=newBufferedReader(isr);
Stringinfo=null;
while((info=br.readLine())!=null){
System.out.println("我是服务器,客户端说:"+info);
}
}

3,添加阻塞代码:

	Semaphoresemaphore=newSemaphore(0);
try{
semaphore.acquire();
}catch(InterruptedExceptione){
//TODOAuto-generatedcatchblock
e.printStackTrace();
}

这段代码是不占cpu的。它会让出cpu的执行权。

Ⅱ jpush推送java后台怎么调用

原创作品,可以转载,但是请标注出处地址http://www.cnblogs.com/V1haoge/p/6439313.html

Java后台实现极光推送有两种方式,一种是使用极光推送官方提供的推送请求API:https://api.jpush.cn/v3/push,另一种则是使用官方提供的第三方Java SDK,这里先进行第一种方式推送的实现代码:

importorg.apache.http.HttpResponse;
importorg.apache.http.client.HttpClient;
importorg.apache.http.client.methods.HttpPost;
importorg.apache.http.entity.StringEntity;
importorg.apache.http.impl.client.DefaultHttpClient;
importorg.apache.http.util.EntityUtils;
importorg.slf4j.Logger;
importorg.slf4j.LoggerFactory;
importcom.alibaba.fastjson.JSONArray;
importnet.sf.json.JSONObject;
importsun.misc.BASE64Encoder;
/**
*java后台极光推送方式一:使用HttpAPI
*此种方式需要自定义http请求发送客户端:HttpClient
*/
@SuppressWarnings({"deprecation","restriction"})
publicclassJiguangPush{
privatestaticfinalLoggerlog=LoggerFactory.getLogger(JiguangPush.class);
privateStringmasterSecret="xxxxxxxxxxxxxxxxxxxx";
privateStringappKey="xxxxxxxxxxxxxxxxxxx";
privateStringpushUrl="https://api.jpush.cn/v3/push";
privatebooleanapns_proction=true;
privateinttime_to_live=86400;
privatestaticfinalStringALERT="推送信息";
/**
*极光推送
*/
publicvoidjiguangPush(){
Stringalias="123456";//声明别名
try{
Stringresult=push(pushUrl,alias,ALERT,appKey,masterSecret,apns_proction,time_to_live);
JSONObjectresData=JSONObject.fromObject(result);
if(resData.containsKey("error")){
log.info("针对别名为"+alias+"的信息推送失败!");
JSONObjecterror=JSONObject.fromObject(resData.get("error"));
log.info("错误信息为:"+error.get("message").toString());
}
log.info("针对别名为"+alias+"的信息推送成功!");
}catch(Exceptione){
log.error("针对别名为"+alias+"的信息推送失败!",e);
}
}

/**
*组装极光推送专用json串
*@paramalias
*@paramalert
*@returnjson
*/
(Stringalias,Stringalert,booleanapns_proction,inttime_to_live){
JSONObjectjson=newJSONObject();
JSONArrayplatform=newJSONArray();//平台
platform.add("android");
platform.add("ios");

JSONObjectaudience=newJSONObject();//推送目标
JSONArrayalias1=newJSONArray();
alias1.add(alias);
audience.put("alias",alias1);

JSONObjectnotification=newJSONObject();//通知内容
JSONObjectandroid=newJSONObject();//android通知内容
android.put("alert",alert);
android.put("builder_id",1);
JSONObjectandroid_extras=newJSONObject();//android额外参数
android_extras.put("type","infomation");
android.put("extras",android_extras);

JSONObjectios=newJSONObject();//ios通知内容
ios.put("alert",alert);
ios.put("sound","default");
ios.put("badge","+1");
JSONObjectios_extras=newJSONObject();//ios额外参数
ios_extras.put("type","infomation");
ios.put("extras",ios_extras);
notification.put("android",android);
notification.put("ios",ios);

JSONObjectoptions=newJSONObject();//设置参数
options.put("time_to_live",Integer.valueOf(time_to_live));
options.put("apns_proction",apns_proction);

json.put("platform",platform);
json.put("audience",audience);
json.put("notification",notification);
json.put("options",options);
returnjson;

}

/**
*推送方法-调用极光API
*@paramreqUrl
*@paramalias
*@paramalert
*@returnresult
*/
publicstaticStringpush(StringreqUrl,Stringalias,Stringalert,StringappKey,StringmasterSecret,booleanapns_proction,inttime_to_live){
Stringbase64_auth_string=encryptBASE64(appKey+":"+masterSecret);
Stringauthorization="Basic"+base64_auth_string;
returnsendPostRequest(reqUrl,generateJson(alias,alert,apns_proction,time_to_live).toString(),"UTF-8",authorization);
}

/**
*发送Post请求(json格式)
*@paramreqURL
*@paramdata
*@paramencodeCharset
*@paramauthorization
*@returnresult
*/
@SuppressWarnings({"resource"})
(StringreqURL,Stringdata,StringencodeCharset,Stringauthorization){
HttpPosthttpPost=newHttpPost(reqURL);
HttpClientclient=newDefaultHttpClient();
HttpResponseresponse=null;
Stringresult="";
try{
StringEntityentity=newStringEntity(data,encodeCharset);
entity.setContentType("application/json");
httpPost.setEntity(entity);
httpPost.setHeader("Authorization",authorization.trim());
response=client.execute(httpPost);
result=EntityUtils.toString(response.getEntity(),encodeCharset);
}catch(Exceptione){
log.error("请求通信["+reqURL+"]时偶遇异常,堆栈轨迹如下",e);
}finally{
client.getConnectionManager().shutdown();
}
returnresult;
}
/**
*BASE64加密工具
*/
(Stringstr){
byte[]key=str.getBytes();
BASE64Encoderbase64Encoder=newBASE64Encoder();
Stringstrs=base64Encoder.encodeBuffer(key);
returnstrs;
}
}

以上代码中使用的是第一种方式实现推送,下面介绍第二种方式:使用java SDK

importorg.slf4j.Logger;
importorg.slf4j.LoggerFactory;
importcn.jiguang.common.ClientConfig;
importcn.jiguang.common.resp.APIConnectionException;
importcn.jiguang.common.resp.APIRequestException;
importcn.jpush.api.JPushClient;
importcn.jpush.api.push.PushResult;
importcn.jpush.api.push.model.Options;
importcn.jpush.api.push.model.Platform;
importcn.jpush.api.push.model.PushPayload;
importcn.jpush.api.push.model.audience.Audience;
importcn.jpush.api.push.model.notification.AndroidNotification;
importcn.jpush.api.push.model.notification.IosNotification;
importcn.jpush.api.push.model.notification.Notification;
/**
*java后台极光推送方式二:使用JavaSDK
*/
@SuppressWarnings({"deprecation","restriction"})
publicclassJiguangPush{
privatestaticfinalLoggerlog=LoggerFactory.getLogger(JiguangPush.class);
="xxxxxxxxxxxxxxxxx";
privatestaticStringappKey="xxxxxxxxxxxxxxxx";
privatestaticfinalStringALERT="推送信息";
/**
*极光推送
*/
publicvoidjiguangPush(){
Stringalias="123456";//声明别名
log.info("对别名"+alias+"的用户推送信息");
PushResultresult=push(String.valueOf(alias),ALERT);
if(result!=null&&result.isResultOK()){
log.info("针对别名"+alias+"的信息推送成功!");
}else{
log.info("针对别名"+alias+"的信息推送失败!");
}
}

/**
*生成极光推送对象PushPayload(采用javaSDK)
*@paramalias
*@paramalert
*@returnPushPayload
*/
_android_ios_alias_alert(Stringalias,Stringalert){
returnPushPayload.newBuilder()
.setPlatform(Platform.android_ios())
.setAudience(Audience.alias(alias))
.setNotification(Notification.newBuilder()
.addPlatformNotification(AndroidNotification.newBuilder()
.addExtra("type","infomation")
.setAlert(alert)
.build())
.addPlatformNotification(IosNotification.newBuilder()
.addExtra("type","infomation")
.setAlert(alert)
.build())
.build())
.setOptions(Options.newBuilder()
.setApnsProction(false)//true-推送生产环境false-推送开发环境(测试使用参数)
.setTimeToLive(90)//消息在JPush服务器的失效时间(测试使用参数)
.build())
.build();
}
/**
*极光推送方法(采用javaSDK)
*@paramalias
*@paramalert
*@returnPushResult
*/
publicstaticPushResultpush(Stringalias,Stringalert){
ClientConfigclientConfig=ClientConfig.getInstance();
JPushClientjpushClient=newJPushClient(masterSecret,appKey,null,clientConfig);
PushPayloadpayload=buildPushObject_android_ios_alias_alert(alias,alert);
try{
returnjpushClient.sendPush(payload);
}catch(APIConnectionExceptione){
log.error("Connectionerror.Shouldretrylater.",e);
returnnull;
}catch(APIRequestExceptione){
log.error("ErrorresponsefromJPushserver.Shouldreviewandfixit.",e);
log.info("HTTPStatus:"+e.getStatus());
log.info("ErrorCode:"+e.getErrorCode());
log.info("ErrorMessage:"+e.getErrorMessage());
log.info("MsgID:"+e.getMsgId());
returnnull;
}
}
}

可以看出使用Java SDK实现推送的方式很简单,代码量也少,理解起来也不难,官方提供的SDK中讲很多内容都实现了,我们只是需要配置一下信息,然后发起推送即可。需要注意的是使用第二种方式,需要导入极光官网提供的jar包。

直接在maven中的pom文件中加入:

<dependency>
<groupId>cn.jpush.api</groupId>
<artifactId>jpush-client</artifactId>
<version>3.2.15</version>
</dependency>

注意:在这里极有可能会出现jar包冲突:具体哪个包我也忘记了,好像是个日志包,你找到后删除即可。

原本我们项目中也是采用第二种方式实现的,但是最后在提交代码时发现一个问题,那就是虽然我们只是带入了官网提供的那三个jar包,但是最后一统计,竟然无缘无故增多了80+个jar包,如此多的jar包提交过于臃肿,而且不现实,所以才临时改变方案,采用第一种方式进行编码。

代码中采用的是别名方式进行推送,需要在在手机APP端进行别名设置,最好就是在用户登录之后就设置好,这样只要用户登录一次,它的绑定别名就可以保存到极光服务器,而我们推送时,指定这个别名,就能将信息推送到对应用户的手机上。

其实我们发起推送请求,只是将信息发送到了极光服务器之上,这个信息有一个保存时限,默认一天,只要用户登录手机APP,极光服务器就会将信息自动推送到对应别名的手机上,由此可见,信息并非由我们后天直接推送到手机,而是通过极光服务器这个中转站,而这正式极光的工作。

注意:这里告知一个技巧,这个别名设置的时候,其实直接将用户ID设置为别名即可,既方便,又安全,不用再去想办法生成一个唯一的串来进行标识,甚至需要在后台数据库中用户表中新增字段。

Ⅲ 怎么查看一个springboot项目的源代码在哪

要查看基于Spring Boot的Java项目的代码,您需要进行以下步骤:

  • 查看项目结构:您可以在部署项目的位置找到项目文件夹。打开项目文件夹并查看项目结构。您可以找到源代码文件夹(通常是“src”文件夹),该文件夹中包含Java源代码辩庆文件。您也可以找到配置文件,资源文件和其他相关文件。

  • 查看源代码:在源代码文件夹中,您可以找到Java文件,这些文件包含应用程序的代码逻辑。您可以使用任何文本编辑器或IDE(集成开发环境)打开这些文件。IDE(如Eclipse、IntelliJ IDEA)通常提供更好的开发环境和代码阅读功能。

  • 寻找关键词:如果您不知道源代码的特定位置,请尝试在项目中搜索关键词或特定函数。您可以使用文本编携庆握辑器或IDE的搜索功能来搜索关键词。

  • 调试代码:如果您想深入了解代码差胡的实际执行过程,可以使用IDE的调试工具。在调试模式下,您可以单步执行代码,并查看变量值和执行结果。

  • 总之,查看基于Spring Boot的Java项目代码需要一定的编程知识和经验。如果您不熟悉Java编程语言或Spring框架,建议您先学习这些知识,然后再尝试查看项目代码。

Ⅳ ...怎么查看导入的一个java项目的后台各功能源代码在哪

要查看导入的一个Java项目的后台各功能源代码位置,可以按照以下步骤进行:

  1. 确认项目的MVC结构

    • 大多数Java Web项目采用MVC架构。在这种架构中,Controller层负责处理HTTP请求。
  2. 找到Controller包

    • 在IDE中,项目的源代码通常按包组织。Controller层的代码一般位于名为controller或类似名称的包中。
  3. 使用浏览器开发者控制台

    • 打开你的Web应用程序,并使用浏览器的开发者控制台。
    • 在“网络”标签页中,观察发出的HTTP请求。注意请求的URL路径。
  4. 在IDE中搜索请求路径

    • 回到IDE,右键点击项目根目录,选择“Find in Path”。
    • 输入从浏览器开发者控制台中获取的请求路径。例如,如果请求路径是/getinfo,则只输入getinfo进行搜索。
    • 这应该会帮助你定位到处理该请求的Controller接口源代码。
  5. 使用Restful Toolkit插件

    • 如果直接搜索路径没有结果,可以考虑在IDE中安装Restful Toolkit插件。
    • 安装并重启IDE后,使用插件提供的快捷键来搜索RESTful接口。这可能会提供更直接的接口定位方式。

总结: 首先确认项目的MVC结构,并找到Controller包。 使用浏览器开发者控制台找到具体的请求路径。 在IDE中使用“Find in Path”功能搜索请求路径,定位到Controller源代码。 如果需要,可以安装并使用Restful Toolkit插件来辅助搜索。

热点内容
百度云种子服务器异常 发布:2025-08-11 20:43:19 浏览:194
三星忘记备用密码怎么办 发布:2025-08-11 20:19:57 浏览:841
假4轴编程 发布:2025-08-11 20:12:39 浏览:873
文件夹后退 发布:2025-08-11 20:00:38 浏览:904
安卓手机怎么禁用所有软件 发布:2025-08-11 19:50:33 浏览:787
思科怎样搭建ftp服务器 发布:2025-08-11 19:50:25 浏览:616
dvd光盘加密怎么复制 发布:2025-08-11 19:49:14 浏览:527
服务器端ip和端口号是固定的吗 发布:2025-08-11 19:47:36 浏览:15
安卓系统书哪个好用 发布:2025-08-11 19:47:00 浏览:330
远程主机允许匿名ftp登录 发布:2025-08-11 19:00:45 浏览:210