java獲取url,java獲取url後面的參數

本文目錄一覽:

java獲取URL

import java.io.BufferedReader;

import java.io.IOException;

import java.io.InputStreamReader;

import java.net.MalformedURLException;

import java.net.URL;

import java.util.ArrayList;

import java.util.List;

public class GetLinks {

private String webSource;

private String url;

public GetLinks(String url) throws MalformedURLException, IOException {

this.url = Complete(url);

webSource = getWebCon(this.url);

}

private String getWebCon(String strURL) throws MalformedURLException,

IOException {

StringBuffer sb = new StringBuffer();

java.net.URL url = new java.net.URL(strURL);

BufferedReader in = new BufferedReader(new InputStreamReader(url

.openStream()));

String line;

while ((line = in.readLine()) != null) {

sb.append(line);

}

in.close();

return sb.toString();

}

private String Complete(String link)throws MalformedURLException{

URL url1 = new URL(link);

URL url2 = new URL(link+”/”);

String handledUrl = link;

try{

StringBuffer sb1 = new StringBuffer();

BufferedReader in1 = new BufferedReader(new InputStreamReader(url1

.openStream()));

String line1;

while ((line1 = in1.readLine()) != null) {

sb1.append(line1);

}

in1.close();

StringBuffer sb2 = new StringBuffer();

BufferedReader in2 = new BufferedReader(new InputStreamReader(url2

.openStream()));

String line2;

while ((line2 = in2.readLine()) != null) {

sb2.append(line2);

}

in1.close();

if(sb1.toString().equals(sb2.toString())){

handledUrl = link+”/”;

}

}catch(Exception e){

handledUrl = link;

}

return handledUrl;

}

/**

* 處理鏈接的相對路徑

* @param link 相對路徑或絕對路徑

* @return 絕對路徑

*/

private String urlHandler(String link) {

if (link == null)

return null;

link = link.trim();

if (link.toLowerCase().startsWith(“http://”)

|| link.toLowerCase().startsWith(“https://”)) {

return link;

}

String pare = url.trim();

if (!link.startsWith(“/”)) {

if (pare.endsWith(“/”)) {

return pare + link;

}

if (url.lastIndexOf(“/”) == url.indexOf(“//”) + 1 || url.lastIndexOf(“/”) == url.indexOf(“//”) + 2) {

return pare + “/” + link;

} else {

int lastSeparatorIndex = url.lastIndexOf(“/”);

return url.substring(0, lastSeparatorIndex + 1) + link;

}

}else{

if (url.lastIndexOf(“/”) == url.indexOf(“//”) + 1 || url.lastIndexOf(“/”) == url.indexOf(“//”) + 2) {

return pare + link;

}else{

return url.substring(0,url.indexOf(“/”, url.indexOf(“//”)+3)) + link;

}

}

}

public ListString getAnchorTagUrls() {

if (webSource == null) {

System.out.println(“沒有網頁源代碼”);

return null;

}

ArrayListString list = new ArrayListString();

int index = 0;

while (index != -1) {

index = webSource.toLowerCase().indexOf(“a “, index);

if (index != -1) {

int end = webSource.indexOf(“”, index);

String str = webSource.substring(index, end == -1 ? webSource

.length() : end);

str = str.replaceAll(“\\s*=\\s*”, “=”);

if (str.toLowerCase().matches(“^a.*href\\s*=\\s*[\’|\”]?.*”)) {// “^a\\s+\\w*\\s*href\\s*=\\s*[\’|\”]?.*”

int hrefIndex = str.toLowerCase().indexOf(“href=”);

int leadingQuotesIndex = -1;

if ((leadingQuotesIndex = str.indexOf(“\””, hrefIndex

+ “href=”.length())) != -1) { // 形如a

// href=”…..”

int TrailingQuotesIndex = str.indexOf(“\””,

leadingQuotesIndex + 1);

TrailingQuotesIndex = TrailingQuotesIndex == -1 ? str

.length() : TrailingQuotesIndex;

str = str.substring(leadingQuotesIndex + 1,

TrailingQuotesIndex);

str = urlHandler(str);

list.add(str);

System.out.println(str);

index += “a “.length();

continue;

}

if ((leadingQuotesIndex = str.indexOf(“\'”, hrefIndex

+ “href=”.length())) != -1) { // 形如a

// href=’…..’

int TrailingQuotesIndex = str.indexOf(“\'”,

leadingQuotesIndex + 1);

TrailingQuotesIndex = TrailingQuotesIndex == -1 ? str

.length() : TrailingQuotesIndex;

str = str.substring(leadingQuotesIndex + 1,

TrailingQuotesIndex);

str = urlHandler(str);

System.out.println(str);

list.add(str);

index += “a “.length();

continue;

}

int whitespaceIndex = str.indexOf(” “, hrefIndex

+ “href=”.length()); // 形如a href=

//

whitespaceIndex = whitespaceIndex == -1 ? str.length()

: whitespaceIndex;

str = str.substring(hrefIndex + “href=”.length(),

whitespaceIndex);

str = urlHandler(str);

list.add(str);

System.out.println(str);

}

index += “a “.length();

}

}

return list;

}

public static void main(String[] args) throws Exception {

GetLinks gl = new GetLinks(“”);

ListString list = gl.getAnchorTagUrls();

for(String str:list) {

System.out.println(str);

}

}

}

請問java如何獲取當前url路徑?

1、利用System.getProperty()函數獲取當前路徑:

System.out.println(System.getProperty(“user.dir”));//user.dir指定了當前的路徑

2、使用File提供的函數獲取當前路徑:

File directory = new File(“”);//設定為當前文件夾

try{

System.out.println(directory.getCanonicalPath());//獲取標準的路徑

System.out.println(directory.getAbsolutePath());//獲取絕對路徑

}catch(Exceptin e){}

File.getCanonicalPath()和File.getAbsolutePath()大約只是對於new File(“.”)和new File(“..”)兩種路徑有所區別。

# 對於getCanonicalPath()函數,“.”就表示當前的文件夾,而”..“則表示當前文件夾的上一級文件夾

# 對於getAbsolutePath()函數,則不管”.”、“..”,返回當前的路徑加上你在new File()時設定的路徑

# 至於getPath()函數,得到的只是你在new File()時設定的路徑

java怎樣獲取url參數

如果是javaweb 項目,那麼非常簡單,直接調用 HttpServletRequest 對象的 .getParamter(“參數名稱”) 方法即可得到。

如果是普通java 項目:

/**

* 獲取網址的指定參數值

*

* @param url

* 網址

* @param parameter

* 參數名稱

* @author cevencheng

* @return

*/

public static String getParameter(String url, String parameter, String defaultValue) {

try {

final String charset = “utf-8”;

url = URLDecoder.decode(url, charset);

if (url.indexOf(‘?’) != -1) {

final String contents = url.substring(url.indexOf(‘?’) + 1);

HashMapString, String map = new HashMapString, String();

String[] keyValues = contents.split(“”);

for (int i = 0; i keyValues.length; i++) {

String key = keyValues[i].substring(0, keyValues[i].indexOf(“=”));

String value = keyValues[i].substring(keyValues[i].indexOf(“=”) + 1);

if (key.equals(parameter)) {

if (value == null || “”.equals(value.trim())) {

return defaultValue;

}

return value;

}

map.put(key, value);

}

}

return null;

} catch (Exception e) {

e.printStackTrace();

}

return null;

}

java怎麼獲取url上的參數

解析url,本想用正則表達式處理,但正則表達式速度較慢。用split處理一下就可以了。

package RequestPackage;

import java.util.HashMap;

import java.util.Map;

public class CRequest {

/**

* 解析出url請求的路徑,包括頁面

* @param strURL url地址

* @return url路徑

*/

public static String UrlPage(String strURL)

{

String strPage=null;

String[] arrSplit=null;

strURL=strURL.trim().toLowerCase();

arrSplit=strURL.split(“[?]”);

if(strURL.length()0)

{

if(arrSplit.length1)

{

if(arrSplit[0]!=null)

{

strPage=arrSplit[0];

}

}

}

return strPage;

}

/**

* 去掉url中的路徑,留下請求參數部分

* @param strURL url地址

* @return url請求參數部分

*/

private static String TruncateUrlPage(String strURL)

{

String strAllParam=null;

String[] arrSplit=null;

strURL=strURL.trim().toLowerCase();

arrSplit=strURL.split(“[?]”);

if(strURL.length()1)

{

if(arrSplit.length1)

{

if(arrSplit[1]!=null)

{

strAllParam=arrSplit[1];

}

}

}

return strAllParam;

}

/**

* 解析出url參數中的鍵值對

* 如 “index.jsp?Action=delid=123″,解析出Action:del,id:123存入map中

* @param URL url地址

* @return url請求參數部分

*/

public static MapString, String URLRequest(String URL)

{

MapString, String mapRequest = new HashMapString, String();

String[] arrSplit=null;

String strUrlParam=TruncateUrlPage(URL);

if(strUrlParam==null)

{

return mapRequest;

}

//每個鍵值為一組

arrSplit=strUrlParam.split(“[]”);

for(String strSplit:arrSplit)

{

String[] arrSplitEqual=null;

arrSplitEqual= strSplit.split(“[=]”);

//解析出鍵值

if(arrSplitEqual.length1)

{

//正確解析

mapRequest.put(arrSplitEqual[0], arrSplitEqual[1]);

}

else

{

if(arrSplitEqual[0]!=””)

{

//只有參數沒有值,不加入

mapRequest.put(arrSplitEqual[0], “”);

}

}

}

return mapRequest;

}

}

測試類

package RequestPackage;

import java.util.Map;

public class TestCRequest {

/**用於測試CRequest類

* @param args

*/

public static void main(String[] args) {

// 請求url

String str = “index.jsp?Action=delid=123sort=”;

//url頁面路徑

System.out.println(CRequest.UrlPage(str));

//url參數鍵值對

String strRequestKeyAndValues=””;

MapString, String mapRequest = CRequest.URLRequest(str);

for(String strRequestKey: mapRequest.keySet()) {

String strRequestValue=mapRequest.get(strRequestKey);

strRequestKeyAndValues+=”key:”+strRequestKey+”,Value:”+strRequestValue+”;”;

}

System.out.println(strRequestKeyAndValues);

//獲取無效鍵時,輸出null

System.out.println(mapRequest.get(“page”));

}

}

原創文章,作者:DSDY,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/148167.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
DSDY的頭像DSDY
上一篇 2024-11-02 13:15
下一篇 2024-11-02 13:15

相關推薦

  • Java JsonPath 效率優化指南

    本篇文章將深入探討Java JsonPath的效率問題,並提供一些優化方案。 一、JsonPath 簡介 JsonPath是一個可用於從JSON數據中獲取信息的庫。它提供了一種DS…

    編程 2025-04-29
  • java client.getacsresponse 編譯報錯解決方法

    java client.getacsresponse 編譯報錯是Java編程過程中常見的錯誤,常見的原因是代碼的語法錯誤、類庫依賴問題和編譯環境的配置問題。下面將從多個方面進行分析…

    編程 2025-04-29
  • Java騰訊雲音視頻對接

    本文旨在從多個方面詳細闡述Java騰訊雲音視頻對接,提供完整的代碼示例。 一、騰訊雲音視頻介紹 騰訊雲音視頻服務(Cloud Tencent Real-Time Communica…

    編程 2025-04-29
  • Java Bean加載過程

    Java Bean加載過程涉及到類加載器、反射機制和Java虛擬機的執行過程。在本文中,將從這三個方面詳細闡述Java Bean加載的過程。 一、類加載器 類加載器是Java虛擬機…

    編程 2025-04-29
  • Java Milvus SearchParam withoutFields用法介紹

    本文將詳細介紹Java Milvus SearchParam withoutFields的相關知識和用法。 一、什麼是Java Milvus SearchParam without…

    編程 2025-04-29
  • Java 8中某一周的周一

    Java 8是Java語言中的一個版本,於2014年3月18日發布。本文將從多個方面對Java 8中某一周的周一進行詳細的闡述。 一、數組處理 Java 8新特性之一是Stream…

    編程 2025-04-29
  • 三星內存條參數用法介紹

    本文將詳細解釋三星內存條上面的各種參數,讓你更好地了解內存條並選擇適合自己的一款。 一、容量大小 容量大小是內存條最基本的參數,一般以GB為單位表示,常見的有2GB、4GB、8GB…

    編程 2025-04-29
  • Python3定義函數參數類型

    Python是一門動態類型語言,不需要在定義變量時顯示的指定變量類型,但是Python3中提供了函數參數類型的聲明功能,在函數定義時明確定義參數類型。在函數的形參後面加上冒號(:)…

    編程 2025-04-29
  • Java判斷字符串是否存在多個

    本文將從以下幾個方面詳細闡述如何使用Java判斷一個字符串中是否存在多個指定字符: 一、字符串遍歷 字符串是Java編程中非常重要的一種數據類型。要判斷字符串中是否存在多個指定字符…

    編程 2025-04-29
  • VSCode為什麼無法運行Java

    解答:VSCode無法運行Java是因為默認情況下,VSCode並沒有集成Java運行環境,需要手動添加Java運行環境或安裝相關插件才能實現Java代碼的編寫、調試和運行。 一、…

    編程 2025-04-29

發表回復

登錄後才能評論