为什么使用HttpClient发送json总是返回400?

android手机端需要发送一个json格式的数据,返回的也是json数据。
现在问题出现在,我无论怎么写都返回400,Bad Request。
问题出在哪儿呢?且看代码,感觉该设置的都设置了。
[code="java"]
/**
* POST获取服务端数据,发送的是json格式的数据
* @param urlString
* @param json 需要发送的json数据
* @return
* @throws ClientProtocolException
* @throws IOException
*/
public String getDataFromServerByPostForJson(String urlString,JSONObject json) throws ClientProtocolException, IOException{
String strResult = null;
HttpClient client = new DefaultHttpClient();

    StringEntity entity = new StringEntity(json.toString());
    entity.setContentType(new BasicHeader(HTTP.CONTENT_TYPE, "application/x-www-form-urlencoded"));//"application/octet-stream"
    entity.setContentEncoding(new BasicHeader(HTTP.CONTENT_ENCODING,HTTP.UTF_8));

    HttpPost post = new HttpPost(urlString);
    post.setHeader("Accept", "application/json");
    post.setHeader("Content-Type", "application/json");
    post.setEntity(entity);

    HttpResponse response = client.execute(post);

    if (response.getStatusLine().getStatusCode() == HttpStatus.SC_OK) {
        strResult = EntityUtils.toString(response.getEntity(), HTTP.UTF_8);
    }else{
        post.abort();
        strResult = "Error Response code "
                + response.getStatusLine().getStatusCode() + " :"
                + response.getStatusLine().toString();
        Log.i("tag", strResult);
        return null;
    }
    return strResult;
}

[/code]

有碰到类似的朋友吗?

iteye_7589
iteye_7589 那参数 异常就是副作用了……
大约 6 年之前 回复
gundumw100
gundumw100 经检查,提供的urlString地址有误!
大约 6 年之前 回复

5个回答

发送请求的参数与后台 处理程序 的要求不匹配。

特别是用 spring mvc时,容易出现该问题。

比如
@RequestMapping("/api/ddd")
public @ResponseBody JsonResult
doDummy(@RequestParam("tid')Long id) {
.....
return result;
}

如果发送的url是
http://www.foo.com/api/ddd
没有参数,则400
发送请求
http://www.foo.com/api/ddd?id=2323
因为实际要求的参数是tid不是id,还是会出400错

iteye_7589
iteye_7589 地址不是POST /v14/access_tokens 么?
大约 6 年之前 回复
gundumw100
gundumw100 这是他们网站上的协议,地址:http://developer.thelevelup.com/api-reference/core-concepts/access-tokens/ Post请求为/access_tokens Request POST /access_tokens USERNAME AND PASSWORD AUTHENTICATION { "access_token": { "client_id": "6108ab198c116d351019d7b8b4a6b076f3...", "username": "foo@example.com", "password": "s3cur3" } }
大约 6 年之前 回复
gundumw100
gundumw100 我就怀疑是这个地址有问题。但这是人家给的,我根本不知道具体是什么样的。
大约 6 年之前 回复
gundumw100
gundumw100 我连接的地址是这样的 https://api.thelevelup.com/v13/oauth/access_token组json的时候是这样的: JSONObject json = new JSONObject(); JSONObject accessToken = new JSONObject(); accessToken.put("client_id", clientId); accessToken.put("username", username); accessToken.put("password", password); json.put("access_token", accessToken); 然后调用getDataFromServerByPostForJson(urlString,json),我不知道错在哪里?
大约 6 年之前 回复

在浏览器上直接访问可以吗?

是不是因为 entity.setContentType(new BasicHeader(HTTP.CONTENT_TYPE, "application/x-www-form-urlencoded"));//"application/octet-stream"与下面的post.setHeader("Content-Type", "application/json"); 有冲突问题。都改成application/json试一下。

gundumw100
gundumw100 都试过,没用。
大约 6 年之前 回复

把那些头干掉,根本不用那些东西,直接就能发送

你的urlString是怎么样的?android模拟器桥接的局域网访问主机不是机器本身的局域网,我记得好像是10.0.2.2访问主机的

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
HttpClient调用接口返回json
java的httpclient发送post请求传入 data , data_digest , msg_type, company_id ,四个参数 调用接口一直返回S02,无法返回我想要的json数据怎么办?
HttpClient的循环发送请求,第一次成功,为什么第二次就Read timed out?
public String audits() throws Exception{ init(); /*String ids = "[" + condition.getIds() + "]"; String param="{" + "logId" + ":" + ids + "}";*/ String url = "http://192.168.1.220:8080/servlet/AuditServlet";//测试 PostMethod method = new PostMethod(url); HttpClient httpClient = new HttpClient(); //HttpClient httpClient = new HttpClient(new HttpClientParams(),new SimpleHttpConnectionManager(true)); httpClient.getHttpConnectionManager().getParams().setConnectionTimeout(600000); httpClient.getHttpConnectionManager().getParams().setSoTimeout(600000); try { int maxList = 5000; int lastIndex = maxList; Integer allTotal = 0; Integer allFaild = 0; Integer allSuccess = 0; List<String> lists = java.util.Arrays.asList(condition.getIds().split(",")); int count = lists.size(); List<List<String>> idList = new ArrayList<>(); for (int index = 0; index < count; ) { if (lastIndex >= count) { lastIndex = count; idList.add(lists.subList(index, lastIndex)); break; } else { idList.add(lists.subList(index, lastIndex)); index = lastIndex; // 设置下一批下标 lastIndex = index + (maxList - 1); } } if (CollectionUtils.isNotEmpty(idList)) { for (List<String> subList : idList) { String params="{" + "logId" + ":" + subList + "}"; System.out.println("请求接口参数:" + params); //循环发送请求 RequestEntity entity = new StringRequestEntity(params,"application/json","GBK"); System.out.println(1); method.setRequestEntity(entity); System.out.println(2); httpClient.executeMethod(method); System.out.println("请求接口路径url:" + method.getURI().toString()); System.out.println(3); InputStream in = method.getResponseBodyAsStream(); //下面将stream转换为String StringBuffer sb = new StringBuffer(); InputStreamReader isr = new InputStreamReader(in, "GBK"); char[] b = new char[4096]; for(int n; (n = isr.read(b)) != -1;) { sb.append(new String(b, 0, n)); } String returnStr = sb.toString(); System.out.println("返回接口参数:" + returnStr); JSONObject jasonObject = JSONObject.fromObject(returnStr); Map map = (Map)jasonObject; Object total = map.get("total"); Object faild = map.get("faild"); Object success = map.get("success"); allTotal = allTotal + Integer.valueOf(total.toString()); allFaild = allFaild + Integer.valueOf(faild.toString()); allSuccess = allSuccess + Integer.valueOf(success.toString()); } } String totals = allTotal.toString(); String failds = allFaild.toString(); String successs = allSuccess.toString(); condition.setTotal(totals); condition.setFaild(failds); condition.setSuccess(successs); return "index"; } catch (Exception e) { e.printStackTrace(); throw e; } finally { method.releaseConnection(); } } 第一次返回显示是成功的![图片说明](https://img-ask.csdn.net/upload/201912/25/1577256421_630516.png) 第二次就![图片说明](https://img-ask.csdn.net/upload/201912/25/1577256497_930744.png)
求助!!使用java抓取别的网站发送ajax返回的json数据
求大神请教如何使用java抓取别的网站发送的ajax返回的json数据 网站来源是:http://baidu.lecai.com/lottery/draw/sorts/cqssc.php?phase=20170512023&agentId=5591 我是通过NetWork找到我需要数据的请求地址是: http://baidu.lecai.com/lottery/draw/sorts/ajax_get_draw_data.php?lottery_type=200&date=2017-05-12 我使用httpClient可以获取第一个地址的html信息,可是获取不到第二个地址的json格式数据
关于java Httpclient post 提交JSon数据的问题
我查出数据库的数据 推送给安卓解析, 由于安卓的接口没有做好,我自己做了个 servlst 进行解析。但是不知道怎么拿值! 这是 推送数据的方法! public static String doPost(String url,JSONArray json){ String result=null; DefaultHttpClient client = new DefaultHttpClient(); HttpPost post = new HttpPost(url); JSONObject response = null; try { StringEntity s = new StringEntity(json.toString()); s.setContentEncoding("UTF-8"); s.setContentType("application/json");//发送json数据需要设置contentType post.setEntity(s); HttpResponse res = client.execute(post); if(res.getStatusLine().getStatusCode() == HttpStatus.SC_OK){ HttpEntity entity = res.getEntity(); result = EntityUtils.toString(res.getEntity());// 返回json格式: // response = JSONObject.fromObject(result); } } catch (Exception e) { throw new RuntimeException(e); } return result; } 一下是 servlst 解析的方法 public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { System.out.println("POST请求方式"); response.setContentType("text/html"); PrintWriter out = response.getWriter(); //String param=request.getParameter(""); //接收数据 out.println("<!DOCTYPE HTML PUBLIC \"-//W3C//DTD HTML 4.01 Transitional//EN\">"); out.println("<HTML>"); out.println(" <HEAD><TITLE>A Servlet</TITLE></HEAD>"); out.println(" <BODY>"); out.print(" This is "); out.print(this.getClass()); out.println(", using the POST 200 method"); out.println(" </BODY>"); out.println("</HTML>"); out.flush(); out.close(); }
httpclient接收不到返回数据
![图片说明](https://img-ask.csdn.net/upload/201707/22/1500690435_151245.png) 返回是空![图片说明](https://img-ask.csdn.net/upload/201707/22/1500690578_125808.png)服务端是有值的,但是不知道为什么就是返回不到客户端。用response.getWriter();也没有办法输出,用response.getWriter();进行拼接响应头的形势就会报不是一个正规的json?请问怎么才能让客户端获取到我服务端发送的信息?
关于httpclient4读取网站信息的问题
一个内部网站,想通过java的httpclient4来读取网站某url返回的json数据,先用浏览器工具分析其http响应,发现正常访问该url时提交是post方式的multipart/form-data请求,该请求的请求正文不是一般的xxx=xxxx这样的键值对,而是类似{header:{"code":0,"message":"xxx"}}这样的json字符串,我想问的是这种请求应该如何用httpclient4来发送?
MultipartRequestEntity post 请求发送。接收端用java httpserver httpexchange 接受。能不能单独取出 request sign 两块内容
package com.test.HttpClient; import java.io.IOException; import java.io.UnsupportedEncodingException; import java.nio.charset.Charset; import org.apache.commons.httpclient.HttpClient; import org.apache.commons.httpclient.HttpStatus; import org.apache.commons.httpclient.methods.PostMethod; import org.apache.commons.httpclient.methods.StringRequestEntity; import org.apache.commons.httpclient.methods.multipart.MultipartRequestEntity; import org.apache.commons.httpclient.methods.multipart.Part; import org.apache.commons.httpclient.methods.multipart.StringPart; import org.apache.commons.httpclient.params.HttpConnectionManagerParams; import org.apache.commons.io.IOUtils; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.util.StreamUtils; /** * Hello world! * */ public class HttpClientApp { private static final Logger logger = LoggerFactory.getLogger(HttpClientApp.class); public static void main( String[] args ) { String url="http://127.0.0.1:8081/SpringMvc1/student"; String reqStr="aaaaaaa"; String contentType="application/json"; String charset="UTF-8"; String ss=doPost( url, reqStr, contentType, charset) ; System.out.println("返回内容为1:" +ss); Part[] parts=new Part[2]; parts[0]=new StringPart("request", "请求报文体",charset); parts[1]=new StringPart("sign", "数字签名",charset); url="http://127.0.0.1:8081/SpringMvc1/BossServlet"; // url="http://127.0.0.1:8081/SpringMvc1/fileupload"; String response=doPostMuStr( url, parts) ; System.out.println("返回内容为1:" +response); } /** * 执行一个HTTP POST请求,返回请求响应的HTML * * @param url 请求的URL地址 * @param reqStr 请求的查询参数,可以为null * @param charset 字符集 * @return 返回请求响应的HTML */ public static String doPost(String url, String reqStr, String contentType, String charset) { HttpClient client = new HttpClient(); PostMethod method = new PostMethod(url); try { HttpConnectionManagerParams managerParams = client.getHttpConnectionManager().getParams(); managerParams.setConnectionTimeout(30000); // 设置连接超时时间(单位毫秒) managerParams.setSoTimeout(30000); // 设置读数据超时时间(单位毫秒) method.setRequestEntity(new StringRequestEntity(reqStr, contentType, "utf-8")); client.executeMethod(method); System.out.println("返回的状态码为:" +method.getStatusCode()); if (method.getStatusCode() == HttpStatus.SC_OK) { // return StreamUtils.copyToString(method.getResponseBodyAsStream(), Charset.forName(charset)); return IOUtils.toString(method.getResponseBodyAsStream(),"utf-8"); } } catch (UnsupportedEncodingException e1) { logger.error(e1.getMessage()); return ""; } catch (IOException e) { logger.error("执行HTTP Post请求" + url + "时,发生异常!" + e.toString()); return ""; } finally { method.releaseConnection(); } return null; } /** * 执行一个HTTP POST请求,返回请求响应的HTML * * @param url 请求的URL地址 * @param reqStr 请求的查询参数,可以为null * @param charset 字符集 * @return 返回请求响应的HTML */ public static String doPostMuStr(String url, Part[] reqStr) { HttpClient client = new HttpClient(); PostMethod method = new PostMethod(url); try { HttpConnectionManagerParams managerParams = client.getHttpConnectionManager().getParams(); managerParams.setConnectionTimeout(30000); // 设置连接超时时间(单位毫秒) managerParams.setSoTimeout(30000); // 设置读数据超时时间(单位毫秒) method.setRequestEntity(new MultipartRequestEntity(reqStr, method.getParams())); // method.setContentChunked(true); client.executeMethod(method); System.out.println("返回的状态码为:" +method.getStatusCode()); if (method.getStatusCode() == HttpStatus.SC_OK) { return IOUtils.toString(method.getResponseBodyAsStream(),"utf-8"); } } catch (UnsupportedEncodingException e1) { logger.error(e1.getMessage()); return ""; } catch (IOException e) { logger.error("执行HTTP Post请求" + url + "时,发生异常!" + e.toString()); return ""; } finally { method.releaseConnection(); } return null; } }
LAIui前后台交互,只在页面显示Json数据,没有生成表格
``` public ActionResult Index() { //创建一个URL类 Uri uri = new Uri("http://localhost:65517/"); //创建一个HttpClient客户端对象 HttpClient httpclient = new HttpClient(); //设置HttpClient要获取资源的地址 httpclient.BaseAddress =uri; //发送一个Get方法的请求 var GetAsync= httpclient.GetAsync("api/GLB"); //获取Get方法取到数据后的属性 :Result var typeGetAsync = GetAsync.Result; //判断返回数据的状态 if (typeGetAsync.StatusCode == System.Net.HttpStatusCode.OK) { //定义变量接收结果值 //Content:获取HTTP响应消息的内容 //ReadAsStringAsync():以异步操作将HTTP内容写入流 //Result:获取结果值 var result = typeGetAsync.Content.ReadAsStringAsync().Result; //转换数据格式 var List = JsonConvert.DeserializeObject<List<tb_personal>>(result).ToList(); //释放资源 httpclient.Dispose(); ////return View(List); //var tolist = Json(List, JsonRequestBehavior.AllowGet) // ; var toresult = new { code = 0, msg = "", data = List }; return Json(toresult,JsonRequestBehavior.AllowGet); } else { ViewBag.ErrMsg = "获取数据失败,错误代码" + Response.StatusCode; //释放资源 httpclient.Dispose(); } return View(); } ``` ``` <script> layui.use('demo', function () { var table = layui.table; //第一个实例 table.render({ elem: '#demo' , height: 500 , url: '/GLB/' //数据接口 //, page: true //开启分页 , method: 'get' , cols: [[ //表头 { field: 'P_PID', title: '用户编号', width: 80, sort: true}, { field: 'P_PID', title: '用户编号', width: 80, sort: true, fixed: 'left' }, { field: 'P_Name', title: '姓名', width: 80 }, { field: 'P_Sex', title: '性别', width: 80, sort: true }, { field: 'P_Age', title: '年龄', width: 80 }, { field: 'P_Phone', title: '手机号', width: 177 } ]] }); }); </script> ```
HTTP协议测试的意义到底是什么?
最近在用selenium 进行自动化测试时,发现进行大量数据测试,由于脚本中含有大量的等待时间,造成了运行缓慢,根本无法实现大量数据测试. 萌生了用httpclient通过模拟客户端发送数据包来直接跟服务端进行交互省略中间需要人工操作或自动化脚本的运行时间。 但是由于技术原因无法获取到返回的json文件。想请问大神们,针对这样的想法是否有实现的价值?假如可以,那应该怎么样获取服务端返回的json文件,以及怎样用数据包的形式来模拟业务流程?谢谢
jdk1.7发送不了post请求 jdk1.8却可以
发送post方法: public static String doPost(String url, String params) throws Exception { CloseableHttpClient httpclient = HttpClients.createDefault(); HttpPost httpPost = new HttpPost(url);// 创建httpPost httpPost.setHeader("Accept", "application/json"); httpPost.setHeader("Content-Type", "application/json"); String charSet = "UTF-8"; StringEntity entity = new StringEntity(params, charSet); httpPost.setEntity(entity); CloseableHttpResponse response = null; try { response = httpclient.execute(httpPost); StatusLine status = response.getStatusLine(); int state = status.getStatusCode(); if (state == HttpStatus.SC_OK) { HttpEntity responseEntity = response.getEntity(); String jsonString = EntityUtils.toString(responseEntity); return jsonString; } else{ // logger.error("请求返回:"+state+"("+url+")"); } } finally { if (response != null) { try { response.close(); } catch (IOException e) { e.printStackTrace(); } } try { httpclient.close(); } catch (IOException e) { e.printStackTrace(); } } return null; } 1.7: Exception in thread "main" java.net.SocketException: Connection reset at java.net.SocketInputStream.read(SocketInputStream.java:196) at java.net.SocketInputStream.read(SocketInputStream.java:122) at sun.security.ssl.InputRecord.readFully(InputRecord.java:442) at sun.security.ssl.InputRecord.read(InputRecord.java:480) at sun.security.ssl.SSLSocketImpl.readRecord(SSLSocketImpl.java:927) at sun.security.ssl.SSLSocketImpl.performInitialHandshake(SSLSocketImpl.java:1312) at sun.security.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:1339) at sun.security.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:1323) at org.apache.http.conn.ssl.SSLConnectionSocketFactory.createLayeredSocket(SSLConnectionSocketFactory.java:394) at org.apache.http.conn.ssl.SSLConnectionSocketFactory.connectSocket(SSLConnectionSocketFactory.java:353) at org.apache.http.impl.conn.DefaultHttpClientConnectionOperator.connect(DefaultHttpClientConnectionOperator.java:134) at org.apache.http.impl.conn.PoolingHttpClientConnectionManager.connect(PoolingHttpClientConnectionManager.java:353) at org.apache.http.impl.execchain.MainClientExec.establishRoute(MainClientExec.java:380) at org.apache.http.impl.execchain.MainClientExec.execute(MainClientExec.java:236) at org.apache.http.impl.execchain.ProtocolExec.execute(ProtocolExec.java:184) at org.apache.http.impl.execchain.RetryExec.execute(RetryExec.java:88) at org.apache.http.impl.execchain.RedirectExec.execute(RedirectExec.java:110) at org.apache.http.impl.client.InternalHttpClient.doExecute(InternalHttpClient.java:184) at org.apache.http.impl.client.CloseableHttpClient.execute(CloseableHttpClient.java:82) at org.apache.http.impl.client.CloseableHttpClient.execute(CloseableHttpClient.java:107) at org.tempuri.HttpUtilA.doPost(HttpUtilA.java:77) at org.tempuri.HttpUtilA.main(HttpUtilA.java:58) 1.8: { "bindingUser" : null, "id" : "e5e404dd-e2d8-4988-be49" }
java实现HTTP摘要认证
![图片说明](https://img-ask.csdn.net/upload/201907/10/1562747965_105089.png) ``` /** * 注册 * @param url * @param param * @return * @throws NoSuchAlgorithmException */ @RequestMapping("insureResponsePost") @ResponseBody public String insureResponsePost(String url, String param){ PrintWriter out = null; InputStream is = null; BufferedReader br = null; String result = ""; HttpURLConnection conn = null; StringBuffer strBuffer = new StringBuffer(); CloseableHttpClient httpClient = HttpClients.createDefault(); HttpPost httppost = new HttpPost(url); httppost.addHeader("Content-Type","application/json"); httppost.setEntity(new StringEntity(param,"UTF-8")); try { URL realUrl = new URL(url); conn = (HttpURLConnection) realUrl.openConnection(); // 设置通用的请求属性 conn.setRequestMethod( "POST"); conn.setConnectTimeout(20000); conn.setReadTimeout(300000); conn.setRequestProperty("Charset", "UTF-8"); conn.setRequestProperty( "Content-Type", "application/json"); conn.setRequestProperty( "Content-Encoding", "utf-8"); // 发送POST请求必须设置如下两行 conn.setDoOutput( true); conn.setDoInput( true); conn.setUseCaches( false); // 获取URLConnection对象对应的输出流 out = new PrintWriter(conn.getOutputStream()); // 发送请求参数 out.print(param); // flush输出流的缓冲 out.flush(); System.out.println("======================================================================="); is = conn.getInputStream(); br = new BufferedReader( new InputStreamReader(is)); String line = null; while ((line=br.readLine())!= null) { strBuffer.append(line); } result = strBuffer.toString(); } catch (Exception e) { System. out.println( "发送 POST 请求出现异常!" + e); e.printStackTrace(); } // 使用finally块来关闭输出流、输入流 finally { try { if (out != null) { out.close(); } if (br != null) { br.close(); } if (conn!= null) { conn.disconnect(); } } catch (IOException ex) { ex.printStackTrace(); } } return result; } ``` ``` @RequestMapping("insureResponseBlockGet") @ResponseBody public String insureResponseBlockGet(String url,String username,String password,HttpUriRequest request){ HttpServletResponse response1 = null; MessageDigest md5; // String authorization = request.getHeader("Authorization"); // if (authorization != null) { // if (authorization.startsWith(DIGEST.trim())) { // HashMap<String,String> authFields = splitAuthFields(authorization.substring(7)); // String newResponse = authFields = // } // } System.out.println(username +"\n"+ password); HttpURLConnection hc = null; try { URI serverURI = request.getURI(); Credentials creds = new UsernamePasswordCredentials(username,password); hc = (HttpURLConnection)new URL(url).openConnection(); hc.setConnectTimeout(10000); hc.setReadTimeout(10000); hc.setDoInput(true); hc.setDoOutput(true); hc.setUseCaches(false); md5 = MessageDigest.getInstance("MD5"); BASE64Encoder base = new BASE64Encoder(); String ha1 = base.encode(md5.digest((username+password).getBytes("utf-8"))); String ha2 = base.encode(md5.digest(url.getBytes("utf-8"))); String response = base.encode(md5.digest((ha1+ha2).getBytes("utf-8"))); System.out.println(response); StringBuilder sb = new StringBuilder(); sb.append("Digest"); sb.append("realm").append("=\"realm\","); sb.append("qop").append("=\"auth,auth-int\","); } catch (Exception e) { // TODO Auto-generated catch block e.printStackTrace(); } return ""; } ``` 以上代码只是第一次发送请求,返回401 现在不在明白第二次请求在Authorization字段给出信任书,包含认证信息 MD5加密,求大神赐教
Android http client response500错误,求大神帮忙看看代码!
http://121.42.195.113/usay/register.jsp服务器这里没错啊。。。。但不知道为什么放到安卓上就不行 package com.example.demo_jsom1; import java.io.IOException; import java.util.ArrayList; import java.util.List; import org.apache.http.HttpEntity; import org.apache.http.HttpResponse; import org.apache.http.NameValuePair; import org.apache.http.client.ClientProtocolException; import org.apache.http.client.HttpClient; import org.apache.http.client.entity.UrlEncodedFormEntity; import org.apache.http.client.methods.HttpPost; import org.apache.http.entity.StringEntity; import org.apache.http.impl.client.DefaultHttpClient; import org.apache.http.message.BasicNameValuePair; import org.apache.http.protocol.HTTP; import org.apache.http.util.EntityUtils; import org.json.JSONObject; import android.app.Activity; import android.os.Bundle; import android.os.Handler; import android.os.Message; import android.util.Log; import android.view.View; import android.view.View.OnClickListener; import android.widget.Button; import android.widget.TextView; public class MainActivity extends Activity implements OnClickListener { // 声明控件 //private EditText et_name, et_pass; private TextView tv_result; Handler handler =new Handler(){ @Override //当有消息发送出来的时候就执行Handler的这个方法 public void handleMessage(Message msg){ super.handleMessage(msg); //根据msg需求处理UI switch(msg.what){ case 1: String response = (String) msg.obj; tv_result.setText(response); } } }; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); // 获取控件对象 //et_name = (EditText) findViewById(R.id.et_name); //用户名控件 //et_pass = (EditText) findViewById(R.id.et_pass);//密码控件 //tv_result = (TextView) findViewById(R.id.tv_result);//服务器端返回数据显示的控件 Button a = (Button) findViewById(R.id.login); tv_result = (TextView)findViewById(R.id.JSONtextView); a.setOnClickListener(this); } @Override public void onClick(View v) { // TODO Auto-generated method stub switch(v.getId()) { case R.id.login: SENDREQUEST(); Log.i("connectbutton", "1"); break; default: break; } } private void SENDREQUEST() { // TODO Auto-generated method stub new Thread() { @Override public void run() { try{ //网络传输 HttpClient httpclient = new DefaultHttpClient(); String uri = "http://121.42.195.113/usay/register.action"; HttpPost httppost = new HttpPost(uri); JSONObject obj = new JSONObject(); //放入键值对 obj.put("userAccount", "15602385611"); obj.put("userPassword", "123qwertyuiop"); //封装好发送 httppost.setEntity(new StringEntity(obj.toString()) ); //创建接收实例 HttpResponse reponse = httpclient.execute(httppost); //检验状态吗,如果成功接收数据 HttpEntity entity = reponse.getEntity(); int code = reponse.getStatusLine().getStatusCode(); Log.i("connectif", code +""); if(code == 200) { String rev = EntityUtils.toString(reponse.getEntity()); obj = new JSONObject(rev); //接收数据 String result = obj.getString("result"); //将服务器中返回的结果存放进message中 Message message = new Message(); message.what = 1; //obj传入对象 message.obj = result; handler.sendMessage(message); Log.i("result", result); }else{ Log.i("connectfalse", "4"); } }catch(ClientProtocolException e) { }catch(IOException E){ } catch (Exception e){ e.printStackTrace(); } } }.start(); } } ``` ```
android集合SSH框架服务端应该怎么操作
public class LoginProtocol extends BaseProtocol{ private List<NameValuePair> nameValuePair = new ArrayList<NameValuePair>(); private final static String URL = "http://192.168.1.110:8080/healthServer/login"; public boolean checkLogin(User user){ try { addNameValuePair("name", user.getUsername()); addNameValuePair("password", user.getPassword()); pack(URL); System.out.println("URL是:::::::"+URL); parse(); JSONObject obj = this.getJSON(); System.out.println("输出obj是"+obj); if(obj.getString("result").equals("false")){ return false; }else{ return true; } } catch (Exception e) { e.printStackTrace(); System.out.println("mmmmmmmmmmmmmmmmm"); return false; } } } public class BaseProtocol { private StringBuilder sb = new StringBuilder(); private HttpClient httpClient; private HttpPost httpRequest; private HttpResponse response; private List<NameValuePair> nameValuePair = new ArrayList<NameValuePair>(); BaseProtocol() { httpClient = new DefaultHttpClient(); } /** * 向服务器端发送请求 * * @param url * @throws Exception */ protected void pack(String url) throws Exception { httpClient = new DefaultHttpClient(); httpRequest = new HttpPost(url); try{ httpRequest.setEntity(new UrlEncodedFormEntity(nameValuePair,HTTP.UTF_8)); //取得HTTP response System.out.println("httpRequest是"+httpRequest); System.out.println(nameValuePair+"//////////////////////"); System.out.println("entity是;;;;;;;;;"+httpRequest.getEntity()); response = httpClient.execute(httpRequest); System.out.println(response); }catch (Exception e){ e.printStackTrace(); } } /** * 得到返回数据 * * @param url * @return * @throws Exception */ protected void parse() throws Exception { // TODO 状态处理 500 200 if (response.getStatusLine().getStatusCode() == 200) { System.out.println("ssssssssssssssssss"+response.getStatusLine().getStatusCode()); BufferedReader bufferedReader2 = new BufferedReader( new InputStreamReader(response.getEntity().getContent())); System.out.println("jjjjjjjjjjjjjjjjjjjjjjjjj"+bufferedReader2); for (String s = bufferedReader2.readLine(); s != null; s = bufferedReader2 .readLine()) { sb.append(s); System.out.println(sb+"****************"); } System.out.println("执行Parse()中的If语句了"); } } /** * 向服务器发送信息 * * @param key * @param value */ public void addNameValuePair(String key, String value) { nameValuePair.add(new BasicNameValuePair(key, value)); System.out.println(nameValuePair); } /** * 返回JSONObject对象数据模型 * * @return * @throws JSONException */ public JSONObject getJSON() throws JSONException { return new JSONObject(sb.toString()); } } struts.xml文件: <package name="default" namespace="/" extends="json-default" > <global-results> <result name="error">/main/hint/errorpage/error.jsp</result> <result name="javaerror">/main/hint/errorpage/javaerror.jsp</result> <result name="message">/WEB-INF/main/message.jsp</result> </global-results> <global-exception-mappings> <exception-mapping exception="exception.Exceptions" result="error" /> <exception-mapping exception="java.lang.Exception" result="javaerror" /> </global-exception-mappings> <action name="login" class="action.login.LoginAction" method="logins"> <result name="success2" type="json"><param name="includeProperties">result</param> <param name="ignoreHierarchy">false</param></result> <result name="success1" >/main/loginSuccess.jsp</result> <result name="false" >/main/loginFail.jsp</result> </action> 在loginAnction中我应该怎么处理,怎么接收android传过来的HttpPost,怎么将httpRequest.setEntity(new UrlEncodedFormEntity(nameValuePair,HTTP.UTF_8))中的NameValuePair中的用户信息读出来 或者,我在服务端应该怎么处理,请大神们指点一下,项目现在需要写web和android同时写
android Volley Post请求参数丢失
自定义的Request package cn.flymeal.androidApp.http; import java.io.UnsupportedEncodingException; import java.util.HashMap; import java.util.Map; import com.android.volley.AuthFailureError; import com.android.volley.NetworkResponse; import com.android.volley.ParseError; import com.android.volley.Request; import com.android.volley.Response; import com.android.volley.Response.ErrorListener; import com.android.volley.Response.Listener; import com.android.volley.toolbox.HttpHeaderParser; import com.google.gson.Gson; /** * 自定义网络请求(基于Volley) * * @author zx * @param <T> */ public class GsonRequest<T> extends Request<T> { private static final String PROTOCOL_CHARSET = "utf-8"; private static final String PROTOCOL_CONTENT_TYPE = String.format( "application/json; charset=%s", PROTOCOL_CHARSET); private Gson mGson; private final Listener<T> mListener; private Map<String, String> mParams=new HashMap<String, String>(); ; private Class<T> mClass; private Map<String, String> headers = new HashMap<String, String>(); public GsonRequest(int method, String url, Class<T> cls, Map<String, String> params, Map<String, String> headers, Listener<T> listener, ErrorListener errorListener) { super(method, url, errorListener); mGson = new Gson(); mClass = cls; mListener = listener; mParams = params; this.headers = headers; } /** * 将返回的数据处理 */ @Override protected Response<T> parseNetworkResponse(NetworkResponse response) { try { String jsonString = new String(response.data, HttpHeaderParser.parseCharset(response.headers)); T parseJson = mGson.fromJson(jsonString, mClass); return Response.success(parseJson, HttpHeaderParser.parseCacheHeaders(response)); } catch (UnsupportedEncodingException e) { return Response.error(new ParseError(e)); } } @Override protected void deliverResponse(T response) { mListener.onResponse(response); } @Override public Map<String, String> getHeaders() throws AuthFailureError { return headers != null ? headers : super.getHeaders(); } public void setHeaders(Map<String, String> headers) { this.headers = headers; } @Override public String getBodyContentType() { return PROTOCOL_CONTENT_TYPE; } @Override protected Map<String, String> getParams() throws AuthFailureError { return mParams; } } 这是分装好的一个发送请求的方法 /** * 基于Gson的网络Volley请求(新接口返回数据格式Volley请求) * * @param method * @param url * @param params * @param requestListener */ public void executeGsonRequest(int method, String url, Map<String, String> params, Map<String, String> headers, final RequestListener requestListener) { requestListener.onStart(); request = new GsonRequest<ResponseData>(method, url, ResponseData.class, params, headers, new Listener<ResponseData>() { @Override public void onResponse(ResponseData response) { if (response.getStatus().equals("success")) { requestListener.onSuccess(response.getData()); Log.i("volley", response.toString()); } else { requestListener.onMessage(response.getMsg()); } closeDialog(); } }, new ErrorListener() { @Override public void onErrorResponse(VolleyError error) { error.printStackTrace(); if (error instanceof NetworkError) { } else if (error instanceof ServerError) { } else if (error instanceof AuthFailureError) { } else if (error instanceof ParseError) { } else if (error instanceof NoConnectionError) { } else if (error instanceof TimeoutError) { } requestListener.onError(error); closeDialog(); } }); requestQueue.add(request); } public void checkNum(Context context,String str,RequestListener requestListener){ UrlParamJoin urlJoin=new UrlParamJoin("mvc/order/api/mobile/submitOrder.do"); Map<String, String> headers=new HashMap<String, String>(); headers.put(GlobalConstant.API_VERSION, "v3"); Map<String, String> param=new HashMap<String, String>(); param.put("orderStr", str); FlymealHttpClient httpClient=new FlymealHttpClient(context); httpClient.executeGsonRequest(Method.POST, urlJoin.getUrl(), param, headers, requestListener); } 这是一个业务方法 求大神指导为什么POST请求参数没有传过去 ?在线等!!!1
android控件不展示,求大神解决
小弟刚刚学习android,新手一枚,这两天再搞android通过webservice取的数据展示到listview上 我经过调试,确定数据已经取到,sql也非常简单,select * from table,但是list控件并没有展示到模拟器上,搞了很久也没找到问题的根本,希望有大神能够帮助指点一下,感激不尽 以下是我的android代码: package com.dcdz.carmensys; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.util.ArrayList; import java.util.Collection; import java.util.HashMap; import java.util.Iterator; import java.util.List; import org.apache.http.HttpResponse; import org.apache.http.HttpStatus; import org.apache.http.NameValuePair; import org.apache.http.client.HttpClient; import org.apache.http.client.entity.UrlEncodedFormEntity; import org.apache.http.client.methods.HttpGet; import org.apache.http.client.methods.HttpPost; import org.apache.http.impl.client.DefaultHttpClient; import org.apache.http.message.BasicNameValuePair; import org.apache.http.protocol.HTTP; import org.apache.http.util.EntityUtils; import org.json.JSONArray; import org.json.JSONException; import org.json.JSONObject; import com.dcdz.db.DbHelper; import com.example.carmensys.R; import android.os.Bundle; import android.os.Handler; import android.os.Message; import android.os.StrictMode; import android.annotation.SuppressLint; import android.app.Activity; import android.app.ListActivity; import android.view.Menu; import android.view.View; import android.widget.ListView; import android.widget.SimpleAdapter; public class MainActivity extends ListActivity { DbHelper db=new DbHelper(); private PreparedStatement pstmt; private ResultSet resultSet; ArrayList<HashMap<String,String>> list=new ArrayList<HashMap<String,String>>(); SimpleAdapter sp=null; @SuppressLint("NewApi") @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); Thread th=new Thread(ran); th.start(); } Handler handler=new Handler(){ @Override public void handleMessage(Message msg) { super.handleMessage(msg); showList(); } }; public void showList(){ SimpleAdapter sp=new SimpleAdapter(this, list, R.layout.listitemone, new String[]{"userid","username","usertime"}, new int[]{R.id.userid,R.id.username,R.id.usertime}); setListAdapter(sp); } Runnable ran=new Runnable() { @Override public void run() { getlist(); } }; public void getlist(){ HashMap<String, String> map =new HashMap<String, String>(); String requestUrl="http://192.168.1.104:8080/SysCarMen/servlet/getListServlet"; HttpClient client = new DefaultHttpClient(); // 根据URL创建HttpPost实例 mm HttpPost post = new HttpPost(requestUrl); HttpGet getx=new HttpGet(requestUrl); List<NameValuePair> params = new ArrayList<NameValuePair>(); params.add(new BasicNameValuePair("", "")); try { // 设置URL编码 post.setEntity(new UrlEncodedFormEntity(params, HTTP.UTF_8)); // 发送请求并获取反馈 HttpResponse response = client.execute(post); // 判断请求是否成功处理 if (response.getStatusLine().getStatusCode() == HttpStatus.SC_OK) { // 解析返回的内容 String result = EntityUtils.toString(response.getEntity()); JSONArray jsonArray = new JSONArray(result); JSONObject jsonObject; for (int i = 0; i < jsonArray.length(); i++) { jsonObject = jsonArray.getJSONObject(i); list.add(getMap(jsonObject.toString())); } System.out.println(list.toArray()); } } catch (Exception e) { e.printStackTrace(); } } public static HashMap<String, String> getMap(String jsonString) { JSONObject jsonObject; try { jsonObject = new JSONObject(jsonString); @SuppressWarnings("unchecked") Iterator<String> keyIter = jsonObject.keys(); String key; String value; HashMap<String, String> valueMap = new HashMap<String, String>(); while (keyIter.hasNext()) { key = (String) keyIter.next(); value = jsonObject.get(key).toString(); valueMap.put(key, value); } return valueMap; } catch (JSONException e) { e.printStackTrace(); } return null; } @Override public boolean onCreateOptionsMenu(Menu menu) { // Inflate the menu; this adds items to the action bar if it is present. getMenuInflater().inflate(R.menu.main, menu); return true; } } ``` ```
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它是一个过程,是一个不断累积、不断沉淀、不断总结、善于传达自己的个人见解以及乐于分享的过程。
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过...
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
linux系列之常用运维命令整理笔录
本博客记录工作中需要的linux运维命令,大学时候开始接触linux,会一些基本操作,可是都没有整理起来,加上是做开发,不做运维,有些命令忘记了,所以现在整理成博客,当然vi,文件操作等就不介绍了,慢慢积累一些其它拓展的命令,博客不定时更新 free -m 其中:m表示兆,也可以用g,注意都要小写 Men:表示物理内存统计 total:表示物理内存总数(total=used+free) use...
比特币原理详解
一、什么是比特币 比特币是一种电子货币,是一种基于密码学的货币,在2008年11月1日由中本聪发表比特币白皮书,文中提出了一种去中心化的电子记账系统,我们平时的电子现金是银行来记账,因为银行的背后是国家信用。去中心化电子记账系统是参与者共同记账。比特币可以防止主权危机、信用风险。其好处不多做赘述,这一层面介绍的文章很多,本文主要从更深层的技术原理角度进行介绍。 二、问题引入 假设现有4个人...
程序员接私活怎样防止做完了不给钱?
首先跟大家说明一点,我们做 IT 类的外包开发,是非标品开发,所以很有可能在开发过程中会有这样那样的需求修改,而这种需求修改很容易造成扯皮,进而影响到费用支付,甚至出现做完了项目收不到钱的情况。 那么,怎么保证自己的薪酬安全呢? 我们在开工前,一定要做好一些证据方面的准备(也就是“讨薪”的理论依据),这其中最重要的就是需求文档和验收标准。一定要让需求方提供这两个文档资料作为开发的基础。之后开发...
网页实现一个简单的音乐播放器(大佬别看。(⊙﹏⊙))
今天闲着无事,就想写点东西。然后听了下歌,就打算写个播放器。 于是乎用h5 audio的加上js简单的播放器完工了。 演示地点演示 html代码如下` music 这个年纪 七月的风 音乐 ` 然后就是css`*{ margin: 0; padding: 0; text-decoration: none; list-...
Python十大装B语法
Python 是一种代表简单思想的语言,其语法相对简单,很容易上手。不过,如果就此小视 Python 语法的精妙和深邃,那就大错特错了。本文精心筛选了最能展现 Python 语法之精妙的十个知识点,并附上详细的实例代码。如能在实战中融会贯通、灵活使用,必将使代码更为精炼、高效,同时也会极大提升代码B格,使之看上去更老练,读起来更优雅。
数据库优化 - SQL优化
以实际SQL入手,带你一步一步走上SQL优化之路!
通俗易懂地给女朋友讲:线程池的内部原理
餐盘在灯光的照耀下格外晶莹洁白,女朋友拿起红酒杯轻轻地抿了一小口,对我说:“经常听你说线程池,到底线程池到底是个什么原理?”
经典算法(5)杨辉三角
杨辉三角 是经典算法,这篇博客对它的算法思想进行了讲解,并有完整的代码实现。
使用 Docker 部署 Spring Boot 项目
Docker 技术发展为微服务落地提供了更加便利的环境,使用 Docker 部署 Spring Boot 其实非常简单,这篇文章我们就来简单学习下。首先构建一个简单的 S...
英特尔不为人知的 B 面
从 PC 时代至今,众人只知在 CPU、GPU、XPU、制程、工艺等战场中,英特尔在与同行硬件芯片制造商们的竞争中杀出重围,且在不断的成长进化中,成为全球知名的半导体公司。殊不知,在「刚硬」的背后,英特尔「柔性」的软件早已经做到了全方位的支持与支撑,并持续发挥独特的生态价值,推动产业合作共赢。 而对于这一不知人知的 B 面,很多人将其称之为英特尔隐形的翅膀,虽低调,但是影响力却不容小觑。 那么,在...
面试官:你连RESTful都不知道我怎么敢要你?
干货,2019 RESTful最贱实践
刷了几千道算法题,这些我私藏的刷题网站都在这里了!
遥想当年,机缘巧合入了 ACM 的坑,周边巨擘林立,从此过上了"天天被虐似死狗"的生活… 然而我是谁,我可是死狗中的战斗鸡,智力不够那刷题来凑,开始了夜以继日哼哧哼哧刷题的日子,从此"读题与提交齐飞, AC 与 WA 一色 ",我惊喜的发现被题虐既刺激又有快感,那一刻我泪流满面。这么好的事儿作为一个正直的人绝不能自己独享,经过激烈的颅内斗争,我决定把我私藏的十几个 T 的,阿不,十几个刷题网...
白话阿里巴巴Java开发手册高级篇
不久前,阿里巴巴发布了《阿里巴巴Java开发手册》,总结了阿里巴巴内部实际项目开发过程中开发人员应该遵守的研发流程规范,这些流程规范在一定程度上能够保证最终的项目交付质量,通过在时间中总结模式,并推广给广大开发人员,来避免研发人员在实践中容易犯的错误,确保最终在大规模协作的项目中达成既定目标。 无独有偶,笔者去年在公司里负责升级和制定研发流程、设计模板、设计标准、代码标准等规范,并在实际工作中进行...
SQL-小白最佳入门sql查询一
不要偷偷的查询我的个人资料,即使你再喜欢我,也不要这样,真的不好;
redis分布式锁,面试官请随便问,我都会
文章有点长并且绕,先来个图片缓冲下! 前言 现在的业务场景越来越复杂,使用的架构也就越来越复杂,分布式、高并发已经是业务要求的常态。像腾讯系的不少服务,还有CDN优化、异地多备份等处理。 说到分布式,就必然涉及到分布式锁的概念,如何保证不同机器不同线程的分布式锁同步呢? 实现要点 互斥性,同一时刻,智能有一个客户端持有锁。 防止死锁发生,如果持有锁的客户端崩溃没有主动释放锁,也要保证锁可以正常释...
项目中的if else太多了,该怎么重构?
介绍 最近跟着公司的大佬开发了一款IM系统,类似QQ和微信哈,就是聊天软件。我们有一部分业务逻辑是这样的 if (msgType = "文本") { // dosomething } else if(msgType = "图片") { // doshomething } else if(msgType = "视频") { // doshomething } else { // doshom...
Nginx 原理和架构
Nginx 是一个免费的,开源的,高性能的 HTTP 服务器和反向代理,以及 IMAP / POP3 代理服务器。Nginx 以其高性能,稳定性,丰富的功能,简单的配置和低资源消耗而闻名。 Nginx 的整体架构 Nginx 里有一个 master 进程和多个 worker 进程。master 进程并不处理网络请求,主要负责调度工作进程:加载配置、启动工作进程及非停升级。worker 进程负责处...
“狗屁不通文章生成器”登顶GitHub热榜,分分钟写出万字形式主义大作
一、垃圾文字生成器介绍 最近在浏览GitHub的时候,发现了这样一个骨骼清奇的雷人项目,而且热度还特别高。 项目中文名:狗屁不通文章生成器 项目英文名:BullshitGenerator 根据作者的介绍,他是偶尔需要一些中文文字用于GUI开发时测试文本渲染,因此开发了这个废话生成器。但由于生成的废话实在是太过富于哲理,所以最近已经被小伙伴们给玩坏了。 他的文风可能是这样的: 你发现,...
程序员:我终于知道post和get的区别
是一个老生常谈的话题,然而随着不断的学习,对于以前的认识有很多误区,所以还是需要不断地总结的,学而时习之,不亦说乎
《程序人生》系列-这个程序员只用了20行代码就拿了冠军
你知道的越多,你不知道的越多 点赞再看,养成习惯GitHub上已经开源https://github.com/JavaFamily,有一线大厂面试点脑图,欢迎Star和完善 前言 这一期不算《吊打面试官》系列的,所有没前言我直接开始。 絮叨 本来应该是没有这期的,看过我上期的小伙伴应该是知道的嘛,双十一比较忙嘛,要值班又要去帮忙拍摄年会的视频素材,还得搞个程序员一天的Vlog,还要写BU...
加快推动区块链技术和产业创新发展,2019可信区块链峰会在京召开
11月8日,由中国信息通信研究院、中国通信标准化协会、中国互联网协会、可信区块链推进计划联合主办,科技行者协办的2019可信区块链峰会将在北京悠唐皇冠假日酒店开幕。   区块链技术被认为是继蒸汽机、电力、互联网之后,下一代颠覆性的核心技术。如果说蒸汽机释放了人类的生产力,电力解决了人类基本的生活需求,互联网彻底改变了信息传递的方式,区块链作为构造信任的技术有重要的价值。   1...
Java世界最常用的工具类库
Apache Commons Apache Commons有很多子项目 Google Guava 参考博客
程序员把地府后台管理系统做出来了,还有3.0版本!12月7号最新消息:已在开发中有github地址
第一幕:缘起 听说阎王爷要做个生死簿后台管理系统,我们派去了一个程序员…… 996程序员做的梦: 第一场:团队招募 为了应对地府管理危机,阎王打算找“人”开发一套地府后台管理系统,于是就在地府总经办群中发了项目需求。 话说还是中国电信的信号好,地府都是满格,哈哈!!! 经常会有外行朋友问:看某网站做的不错,功能也简单,你帮忙做一下? 而这次,面对这样的需求,这个程序员...
网易云6亿用户音乐推荐算法
网易云音乐是音乐爱好者的集聚地,云音乐推荐系统致力于通过 AI 算法的落地,实现用户千人千面的个性化推荐,为用户带来不一样的听歌体验。 本次分享重点介绍 AI 算法在音乐推荐中的应用实践,以及在算法落地过程中遇到的挑战和解决方案。 将从如下两个部分展开: AI算法在音乐推荐中的应用 音乐场景下的 AI 思考 从 2013 年 4 月正式上线至今,网易云音乐平台持续提供着:乐屏社区、UGC...
【技巧总结】位运算装逼指南
位算法的效率有多快我就不说,不信你可以去用 10 亿个数据模拟一下,今天给大家讲一讲位运算的一些经典例子。不过,最重要的不是看懂了这些例子就好,而是要在以后多去运用位运算这些技巧,当然,采用位运算,也是可以装逼的,不信,你往下看。我会从最简单的讲起,一道比一道难度递增,不过居然是讲技巧,那么也不会太难,相信你分分钟看懂。 判断奇偶数 判断一个数是基于还是偶数,相信很多人都做过,一般的做法的代码如下...
为什么要学数据结构?
一、前言 在可视化化程序设计的今天,借助于集成开发环境可以很快地生成程序,程序设计不再是计算机专业人员的专利。很多人认为,只要掌握几种开发工具就可以成为编程高手,其实,这是一种误解。要想成为一个专业的开发人员,至少需要以下三个条件: 1) 能够熟练地选择和设计各种数据结构和算法 2) 至少要能够熟练地掌握一门程序设计语言 3) 熟知所涉及的相关应用领域的知识 其中,后两个条件比较容易实现,而第一个...
Android 9.0 init 启动流程
阅读五分钟,每日十点,和您一起终身学习,这里是程序员Android本篇文章主要介绍Android开发中的部分知识点,通过阅读本篇文章,您将收获以下内容:一、启动流程概述一、 启动流程概述Android启动流程跟Linux启动类似,大致分为如下五个阶段。1.开机上电,加载固化的ROM。2.加载BootLoader,拉起Android OS。3.加载Uboot,初始外设,引导Kernel启动等。...
8年经验面试官详解 Java 面试秘诀
作者 |胡书敏 责编 | 刘静 出品 | CSDN(ID:CSDNnews) 本人目前在一家知名外企担任架构师,而且最近八年来,在多家外企和互联网公司担任Java技术面试官,前后累计面试了有两三百位候选人。在本文里,就将结合本人的面试经验,针对Java初学者、Java初级开发和Java开发,给出若干准备简历和准备面试的建议。 Java程序员准备和投递简历的实...
面试官如何考察你的思维方式?
1.两种思维方式在求职面试中,经常会考察这种问题:北京有多少量特斯拉汽车?某胡同口的煎饼摊一年能卖出多少个煎饼?深圳有多少个产品经理?一辆公交车里能装下多少个乒乓球?一个正常成年人有多少根头发?这类估算问题,被称为费米问题,是以科学家费米命名的。为什么面试会问这种问题呢?这类问题能把两类人清楚地区分出来。一类是具有文科思维的人,擅长赞叹和模糊想象,它主要依靠的是人的第一反应和直觉,比如小孩...
前后端分离,我怎么就选择了 Spring Boot + Vue 技术栈?
前两天又有小伙伴私信松哥,问题还是职业规划,Java 技术栈路线这种,实际上对于这一类问题我经常不太敢回答,每个人的情况都不太一样,而小伙伴也很少详细介绍自己的情况,大都是一两句话就把问题抛出来了,啥情况都不了解,就要指出一个方向,这实在是太难了。 因此今天我想从我学习 Spring Boot + Vue 这套技术栈的角度,来和大家聊一聊没有人指导,我是如何一步一步建立起自己的技术体系的。 线上大...
17张图带你解析红黑树的原理!保证你能看懂!
二叉查找树 由于红黑树本质上就是一棵二叉查找树,所以在了解红黑树之前,咱们先来看下二叉查找树。 二叉查找树(Binary Search Tree),也称有序二叉树(ordered binary tree),排序二叉树(sorted binary tree),是指一棵空树或者具有下列性质的二叉树: 若任意结点的左子树不空,则左子树上所有结点的值均小于它的根结点的值; 若任意结点的...
相关热词 c# 输入ip c# 乱码 报表 c#选择结构应用基本算法 c# 收到udp包后回包 c#oracle 头文件 c# 序列化对象 自定义 c# tcp 心跳 c# ice连接服务端 c# md5 解密 c# 文字导航控件
立即提问