導航:首頁 > 編程語言 > java規范請求

java規范請求

發布時間:2025-06-23 11:35:25

java請求一個URL。獲取網站返回的數據。

publicstaticStringSendGET(Stringurl,Stringparam){
Stringresult="";//訪問返回結果
BufferedReaderread=null;//讀取訪問結果

try{
//創建url
URLrealurl=newURL(url+"?"+param);
//打開連接
URLConnectionconnection=realurl.openConnection();
//設置通用的請求屬性
connection.setRequestProperty("accept","*/*");
connection.setRequestProperty("connection","Keep-Alive");
connection.setRequestProperty("user-agent",
"Mozilla/4.0(compatible;MSIE6.0;WindowsNT5.1;SV1)");
//建立連接
connection.connect();
//獲取所有響應頭欄位
Map<String,List<String>>map=connection.getHeaderFields();
//遍歷所有的響應頭欄位,獲取到cookies等
for(Stringkey:map.keySet()){
System.out.println(key+"--->"+map.get(key));
}
//定義BufferedReader輸入流來讀取URL的響應
read=newBufferedReader(newInputStreamReader(
connection.getInputStream(),"UTF-8"));
Stringline;//循環讀取
while((line=read.readLine())!=null){
result+=line;
}
}catch(IOExceptione){
e.printStackTrace();
}finally{
if(read!=null){//關閉流
try{
read.close();
}catch(IOExceptione){
e.printStackTrace();
}
}
}

returnresult;
}

❷ 我的手機寫有JAVA擴展CLDC-1.1/MIDP-2.0是什麼意思啊

J2ME的術語

MIDP
開放分類: 計算機技術、電腦

MIDP(Mobile Information Device Profile,移動信息設備配置文件)建立在 CLDC 的基礎之上,用來描述手機和尋呼機這樣更加具體化的的無線移動設備。

對於 Java ME 平台,MIDP 定義了一個標準的 Java API 集合,此集合與聯網的受限設備配置 CLDC 一起提供了一個面向移動信息設備(如行動電話、雙向尋呼機和無線個人電腦記事本)的完整 Java ME 應用程序運行環境。

MIDP 提供了以下功能:

·顯示工具

·用戶輸入方法

·持久性數據存儲(使用簡單的面向記錄的資料庫模型)

·基於 HTTP 1.1 的網路(使用 CLDC 通用連接框架)

Java 規范請求 (Java Specification Request, jsR)-37 中定義了 MIDP 1.0 標准。

JSR-118 中定義了 MIDP 2.0 標准。

CLDC
開放分類: 計算機技術、電腦

CLDC(Connected Limited Device Configuration,聯網的受限設備配置)是用來開發在無線設備上運行的應用程序所要用到的一組最小的 API。CLDC 描述了所有無線移動設備所需的一個最小級別的功能集合。

對於 Java ME 平台,CLDC 為行動電話、雙向尋呼機以及類似設備定義了基本配置(Java 語言、虛擬機功能和基本類庫)。這些設備具有以下特性:

·總內存量為 128 KB 到 512 KB。

·具有有限電源,如電池。

·可以連接到網路。

·具有相對有限的用戶界面,通常只限文本。

CLDC 1.1 是 CLDC 1.0 規范的修訂版本,包含很多新增功能(例如浮點和弱引用支持)以及其他增強功能。

Java 規范請求 (Java Specification Request, JSR) 30 中詳細指定了 CLDC 1.0 的要求。

JSR 139 中詳細指定了 CLDC 1.1 的要求。

J2ME是一種使用Java語言進行嵌入式設備編程的技術,但是嵌入式設備的種類過於繁多,至少有幾百種之多,為了降低編程的復雜度,SUN公司將所有的嵌入式設備分為了兩大類:
1 CDC(連接設備配置)
有穩定的電源供應
設備性能強勁
例如車載設備、機頂盒等。
2 CLDC(連接有限設備配置)
使用電池供電
設備性能有限
其中手機屬於CLDC類別。
上面的說法都是從硬體劃分的角度來說明CLDC的,下面從程序員的角度來理解一下CLDC的概念。其實對於程序員來說,CLDC主要包含三個部分:
1 Java虛擬機(又稱JVM)
這個是所有Java程序運行的基礎。對於手機來說,在手機出廠以前,已經固化在手機中了,出廠了以後就不能進行修改了。
2 一套標準的API實現
該標準的API主要包含java.io、java.lang、java.util包以及javax.microedition.io包中的部分。這個是規范要求必須實現的API,也固化在手機中,不能修改。
3 本地方法實現
在標準的API中,很多都是介面,這些就要求廠商在手機中提供真實的實現,而且很多本地方法也要求手機廠商進行實現。

❸ 如何在java中發起http和https請求

在Java中,發起HTTP請求的方法如下:

定義了一個名為httpRequest的函數,該函數接收三個參數:請求地址(requestUrl)、請求方式(requestMethod,值為"GET"或"POST")以及需要發送的數據(outputStr)。函數的主要功能是處理HTTP請求。

首先,通過URL類創建一個URL對象,然後使用openConnection方法打開一個到該URL的連接。

設置該連接的屬性:允許輸出和輸入,設置請求方式,並進行連接。

如果需要向伺服器端寫內容(即發送數據),則需要通過conn.getOutputStream()方法獲取一個輸出流,並將數據寫入該輸出流中。

然後,通過conn.getInputStream()方法獲取一個輸入流,讀取伺服器端返回的內容。使用InputStreamReader將輸入流轉換為字元流,並通過BufferedReader進行逐行讀取。

將讀取到的內容逐行添加到一個StringBuffer對象中,並最終返回該對象的字元串表示。

如果在處理過程中發生異常,則會列印堆棧跟蹤信息。

此函數適用於處理GET和POST兩種HTTP請求方式。對於POST請求,可以通過設置請求方法為"POST"並發送數據來實現。

需要注意的是,此函數僅適用於HTTP請求。對於HTTPS請求,需要使用HttpsURLConnection類代替HttpURLConnection類,並在URL對象創建時指定協議為"https"。

在實際應用中,還可以對請求頭進行設置,以滿足不同的需求。例如,可以設置請求頭中的Content-Type為application/x-www-form-urlencoded,以表明發送的數據為表單數據。

此外,還可以通過設置連接超時時間和讀取超時時間來控制請求的響應時間,避免請求長時間無響應。

❹ 如何在java中發起http和https請求

1.寫http請求方法
[java] view plain

//處理http請求 requestUrl為請求地址 requestMethod請求方式,值為"GET"或"POST"
public static String httpRequest(String requestUrl,String requestMethod,String outputStr){
StringBuffer buffer=null;
try{
URL url=new URL(requestUrl);
HttpURLConnection conn=(HttpURLConnection)url.openConnection();
conn.setDoOutput(true);
conn.setDoInput(true);
conn.setRequestMethod(requestMethod);
conn.connect();
//往伺服器端寫內容 也就是發起http請求需要帶的參數
if(null!=outputStr){
OutputStream os=conn.getOutputStream();
os.write(outputStr.getBytes("utf-8"));
os.close();
}
//讀取伺服器端返回的內容
InputStream is=conn.getInputStream();
InputStreamReader isr=new InputStreamReader(is,"utf-8");
BufferedReader br=new BufferedReader(isr);
buffer=new StringBuffer();
String line=null;
while((line=br.readLine())!=null){
buffer.append(line);
}
}catch(Exception e){
e.printStackTrace();
}
return buffer.toString();
}
2.測試。
[java] view plain

public static void main(String[] args){
String s=httpRequest("http://www.qq.com","GET",null);
System.out.println(s);
}
輸出結果為www.qq.com的源代碼,說明請求成功。
註:1).第一個參數url需要寫全地址,即前邊的http必須寫上,不能只寫www.qq.com這樣的。

2).第二個參數是請求方式,一般介面調用會給出URL和請求方式說明。
3).第三個參數是我們在發起請求的時候傳遞參數到所要請求的伺服器,要傳遞的參數也要看介面文檔確定格式,一般是封裝成json或xml.
4).返回內容是String類,但是一般是有格式的json或者xml。
二:發起https請求。
1.https是對鏈接加了安全證書SSL的,如果伺服器中沒有相關鏈接的SSL證書,它就不能夠信任那個鏈接,也就不會訪問到了。所以我們第一步是自定義一個信任管理器。自要實現自帶的X509TrustManager介面就可以了。
[java] view plain

import java.security.cert.CertificateException;
import java.security.cert.X509Certificate;
import javax.net.ssl.X509TrustManager;
public class MyX509TrustManager implements X509TrustManager {
@Override
public void checkClientTrusted(X509Certificate[] chain, String authType)
throws CertificateException {
// TODO Auto-generated method stub
}
@Override
public void checkServerTrusted(X509Certificate[] chain, String authType)
throws CertificateException {
// TODO Auto-generated method stub
}
@Override
public X509Certificate[] getAcceptedIssuers() {
// TODO Auto-generated method stub
return null;
}
}
註:1)需要的包都是java自帶的,所以不用引入額外的包。
2.)可以看到裡面的方法都是空的,當方法為空是默認為所有的鏈接都為安全,也就是所有的鏈接都能夠訪問到。當然這樣有一定的安全風險,可以根據實際需要寫入內容。

2.編寫https請求方法。
[java] view plain

/*
* 處理https GET/POST請求
* 請求地址、請求方法、參數
* */
public static String httpsRequest(String requestUrl,String requestMethod,String outputStr){
StringBuffer buffer=null;
try{
//創建SSLContext
SSLContext sslContext=SSLContext.getInstance("SSL");
TrustManager[] tm={new MyX509TrustManager()};
//初始化
sslContext.init(null, tm, new java.security.SecureRandom());;
//獲取SSLSocketFactory對象
SSLSocketFactory ssf=sslContext.getSocketFactory();
URL url=new URL(requestUrl);
HttpsURLConnection conn=(HttpsURLConnection)url.openConnection();
conn.setDoOutput(true);
conn.setDoInput(true);
conn.setUseCaches(false);
conn.setRequestMethod(requestMethod);
//設置當前實例使用的SSLSoctetFactory
conn.setSSLSocketFactory(ssf);
conn.connect();
//往伺服器端寫內容
if(null!=outputStr){
OutputStream os=conn.getOutputStream();
os.write(outputStr.getBytes("utf-8"));
os.close();
}
//讀取伺服器端返回的內容
InputStream is=conn.getInputStream();
InputStreamReader isr=new InputStreamReader(is,"utf-8");
BufferedReader br=new BufferedReader(isr);
buffer=new StringBuffer();
String line=null;
while((line=br.readLine())!=null){
buffer.append(line);
}
}catch(Exception e){
e.printStackTrace();
}
return buffer.toString();
}
可見和http訪問的方法類似,只是多了SSL的相關處理。
3.測試。先用http請求的方法訪問,再用https的請求方法訪問,進行對比。

http訪問:
[java] view plain

public static void main(String[] args){
String s=httpRequest("https://kyfw.12306.cn/","GET",null);
System.out.println(s);
}
結果為:

https訪問:

[java] view plain

public static void main(String[] args){
String s=httpsRequest("https://kyfw.12306.cn/","GET",null);
System.out.println(s);
}
結果為:

可見https的鏈接一定要進行SSL的驗證或者過濾之後才能夠訪問。

三:https的另一種訪問方式——導入服務端的安全證書。
1.下載需要訪問的鏈接所需要的安全證書。https://kyfw.12306.cn/ 以這個網址為例。
1)在瀏覽器上訪問https://kyfw.12306.cn/。

2)點擊上圖的那個打了×的鎖查看證書。

3)選擇復制到文件進行導出,我們把它導入到java項目所使用的jre的lib文件下的security文件夾中去,我的是這個路徑。D:\Program Files (x86)\Java\jre8\lib\security

註:中間需要選導出格式,就選默認的就行,還需要命名,我命名的是12306.

2.打開cmd,進入到java項目所使用的jre的lib文件下的security目錄。
3.在命令行輸入 Keytool -import -alias 12306 -file 12306.cer -keystore cacerts
4.回車後會讓輸入口令,一般默認是changeit,輸入時不顯示,輸入完直接按回車,會讓確認是否信任該證書,輸入y,就會提示導入成功。

5.導入成功後就能像請求http一樣請求https了。

測試:
[java] view plain

public static void main(String[] args){
String s=httpRequest("https://kyfw.12306.cn/","GET",null);
System.out.println(s);
}
結果:
現在就可以用http的方法請求https了。
註:有時候這一步還是會出錯,那可能是jre的版本不對,我們右鍵run as——run configurations,選擇證書所在的jre之後再運行。

閱讀全文

與java規范請求相關的資料

熱點內容
如何將文件存儲路徑改為d盤 瀏覽:372
哪個app看小說不要錢 瀏覽:46
如何用編程畫出圓周率 瀏覽:317
如何改一款網路手游的數值 瀏覽:676
net生成js文件下載 瀏覽:348
w10文件夾 瀏覽:985
aetrapcode教程 瀏覽:884
文件夾不打開看圖片 瀏覽:4
蘋果手機打開文件方式 瀏覽:124
電腦密碼邊框看不到 瀏覽:644
科華數據客戶是哪些 瀏覽:372
更新lib系統找不到指定的文件 瀏覽:640
手動ghost找不到文件 瀏覽:554
cad畫國旗文件 瀏覽:864
HR系統使用什麼編程語言 瀏覽:563
js判斷方法是否執行完成 瀏覽:973
win10魯大師殘留文件 瀏覽:612
jpg文件如何轉換成圖片 瀏覽:427
vs2010無法找到頭文件 瀏覽:895
pdf無效或損壞的文件 瀏覽:657

友情鏈接