A. java连接百度搜索
1,可以用httpconnection或者apache的httpclient,通过“https://www..com/s?wd=要搜索的关键字”这个URL,获取网络搜索的内容。自己解析。
2,如果想从浏览器打开页面,可以用Runtime.getRuntime().exec("浏览器.exe 要打开的url");
3,如果自己用jni或者jna封装一些webkit之类的,通过java调用也可以。
B. 关于java调用url接口方法的问题
对于具体的数据请求方式、请求方式、响应数据格式要看你的接口要求,这是通用代码:
importjava.io.BufferedReader;
importjava.io.IOException;
importjava.io.InputStreamReader;
importjava.net.HttpURLConnection;
importjava.net.URL;
publicclassTest{
publicstaticvoidmain(String[]args)throwsIOException{
System.out.println(getData());
}
publicstaticStringgetData()throwsIOException{
//创建指定url的url对象,这里的地址是:淘宝商品搜索建议
URLurl=newURL("https://suggest.taobao.com/sug?code=utf-8&q=电脑&callback=cb");
//创建http链接对象
HttpURLConnectioncon=(HttpURLConnection)url.openConnection();
//设置请求方式
con.setRequestMethod("POST");
//打开链接,上一步和该步骤作用相同,可以省略
con.connect();
//获取请求返回内容并设置编码为UTF-8
BufferedReaderreader=newBufferedReader(newInputStreamReader(con.getInputStream(),"UTF-8"));
//将返回数据拼接为字符串
StringBuffersb=newStringBuffer();
//临时字符串
Stringtemp=null;
//获取数据
while((temp=reader.readLine())!=null){
sb.append(temp);
}
//关闭流
reader.close();
returnsb.toString();
}
}
结果:
C. 请问java如何获取当前url路径
可以通过“ 类名.class.getResource("").getPath()”方法实现。
举例:”String path = XMLS.class.getResource("").getPath()“.
解释:以上语句就是获取到XMLS编译后的绝对专路属径(无法获取到java文件路径的,因为java运行的都是class文件)。
D. 怎么用java获取浏览器中url的值,比如自己编写一个程序,当前浏览器显示为百度,如何获取url详细一点
这个页面的路径都是自己指定的,那有获取的
E. java里,如何让程序访问指定网页
访问第一个页面,登陆成功了,会返回sessionid,把取得的sessionid通过cookie传递到第二次访问中,浏览器就是这么实现的,cookie是包含在http请求中。
URL url = new URL(linkPage1);
HttpURLConnection urlConnection = (HttpURLConnection) url.openConnection();
......
//第一次访问后,获得session信息,你可以把session_value打印出来,然后根据格式把jsessionid提取出来
//,注意JSESSIONID=XXX都提取出来,带着JSESSIONID,也许需要用正则表达式
session_value = urlConnection.getHeaderField("Set-Cookie");
String[] sessionId = session_value.split(";");
url = new URL(linkPage2);
urlConnection = (HttpURLConnection) url.openConnection();
//把获取的JSESSIONID=XXX保存到cookie中,然后连接第二页面
urlConnection.setRequestProperty("Cookie", sessionId[0])
urlConnection.connect()
F. JAVA类如何打开网页
JAVA中的类是具备某些共同特征的实体的集合,它是一种抽象的概念,用程序设计的语言来说,类是一种抽象的数据类型,它是对所具有相同特征实体的抽象。所谓对象就是真实世界中的实体,对象与实体是一一对应的,也就是说现实世界中每一个实体都是一个对象,对象是一种具体的概念。JAVA类打开网页有以下方法:
1、java.net.URI uri = new java.net.URI("http://www..com");
java.awt.Desktop.getDesktop().browse(uri);
2、Runtime.getRuntime().exec("rundll32 url.dll,FileProtocolHandler http://www..com");
这两种方法是可以打开,不过只能在服务端打开,如果有另一台机器访问我的机器,执行上边的程序后,也会在我本机显示的页面。
3、如果是让他自动打开可以用robot类模拟鼠标单击右键双击等动作,还可以模拟输入。
4、如果要在网页做复杂操作可以用swt做一个浏览器,可以控制他执行网站里的脚本,这个比较难点。
G. java如何访问带中文路径的url
可以用二进制,先把中文全部转换,然后传值,在服务器中相应的转换为10进制
H. 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 List<String> getAnchorTagUrls() {
if (webSource == null) {
System.out.println("没有网页源代码");
return null;
}
ArrayList<String> list = new ArrayList<String>();
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=
// http://www..com >
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("http://www..com");
List<String> list = gl.getAnchorTagUrls();
for(String str:list) {
System.out.println(str);
}
}
}
I. java , 浏览器输入url地址,获取硬盘某个pdf文件。怎么做 如下图这种效果。
1. 怎样迅速地把网页或链接发送给他人?
文件/发送/ 指令可以立即通过电子邮件发送网页或链接。
2. 如何在新窗口中打开链接?
1. 在页面中直接拖放链接。
2. 拖放链接到地址栏或标签栏。
3. 按下 Shift 键后点击链接。
4. 激活”在新窗口中打开链接“功能。
5. 设置鼠标选项的鼠标按键动作“中键单击”为“打开链接”,然后您就可以单击鼠标中键来打开链接。
3. 怎样打开网页中的地址字串?
1. 选中地址字串,然后拖放到地址栏或标签栏。
2. 选中地址字串,然后选择 文件/新建/所选字符(Ctrl+Shift+T)。
3. 选中地址字串,然后拖放到页面中的任何地方。
4. 怎样快速的打开地址?
1. 启用“一键通”功能,并为指定的 URL 设置一个快捷键。
2. 启用“URL 缩写功能”,然后在地址栏输入相应的缩写。
3. 将 URL 添加到收藏夹,以后就能通过收藏夹选择并打开该URL。
5. 怎样快速的同时打开若干个 URL?
1. 把这些 URL 保存为一个群组,然后可以打开这个群组。
2. 把这些 URL 添加到收藏夹中的同一个文件夹中,然后您可以通过“打开本层链接”来打开。
3. 选中这些文件或链接,然后拖放到主窗口或悬浮监视窗。
6. 怎样快速的关闭一个页面?
1. 按快捷键 F4、Ctrl+F4、Ctrl+W、Ctrl+PageDown。
2. 启用“单击图标关闭标签”,就可通过单击窗口标签的图标来快速关闭。
3. 启用鼠标手势功能,然后执行手势 ↑ → (预设)可关闭当前页。
4. 右键点击标签,选择弹出菜单中的 "关闭" 项。
7. 怎样快速的保存图片?
1. 设置鼠标拖放图片的动作为“保存到收集器”,然后就可以快速地将图片保存到收集器所指定的路径中。
2. 把图片拖动到状态栏的收集器图标,此图片就会自动保存到收集器所指定的路径中。
8. 怎样快速的搜索?
1. 在搜索栏键入关键字后按回车键。
2. 把要搜索的关键字拖放到搜索栏。
3. 把关键字拖放到页面中任何地方。
4. 设置地址栏转到按钮显示搜索引擎菜单,在地址栏输入关键字,点击转到按钮的搜索引擎下拉菜单。
9. 怎样快速的切换选择不同的搜索引擎?
您可以按下 Ctrl 键或 Shift 键并点击弹出的搜索栏菜单,实现临时的切换选择不同的搜索引擎项,相关细节请参看“搜索引擎”。
10. 怎样快速的在页面内搜索某个指定的链接?
在 IE 中,如果想寻找一个您所需要的特定链接,您必须打开源文件并在其中查找,这样很麻烦且效果也不好。在 GreenBrowser 中您可以使用 “链接列表" 对话框来达到这个目的。请参看“页内链接分析”的相关介绍。
11. 怎样快速的显示/隐藏 GreenBrowser?
1. 使用快捷键。默认键是 Ctrl+`,您可以设置新的快捷键。
2. 如果选择了显示悬浮监视窗,双击悬浮窗。
3. 如果选择了显示系统托盘图标,点击这个图标。
12. 怎样使 GreenBrowser 在运行中占用更少的内存资源?
当 GreenBrowser 最小化或关闭到系统托盘时,它将占用最小的物理内存,大约能释放 80% 内存空间。所以当您不使用 GreenBrowser 时,您可以将它最小化或关闭到系统托盘,最小化后还原也有相同的效果。
13. 怎样使用地址栏的字串拖放功能?
1. 拖放: 打开拖放的字串
2. Ctrl+拖放: 搜索拖放的字串
3. Shift+拖放: 将拖放的字串存入搜索栏,但不执行搜索
4. Ctrl+Shift+拖放: 在页面中高亮显示拖动的关键字
14. 怎样使用搜索栏的字串拖放功能?
1. 拖放: 搜索拖放的字串
2. Ctrl+拖放: 在页面中查找拖放的字串
3. Shift+拖放: 将拖放的字串存入搜索栏,但不执行搜索
4. Ctrl+Shift+拖放: 在页面中高亮显示拖动的关键字
15. 怎样直接打开指向的地址?
有一些 URL 象这样的链接: /jump.asp?/。如果您需要直接打开这个指向的地址,请在点击该链接时按下 Ctrl 键 (缺省值)。
16. 怎样快速的改变页面的下载控制方案?
您可以通过页面下载控制菜单来改变下载控制方案,您点选菜单项后,页面将随之自动刷新,如果您不需要这样,请在点选菜单项时按下 Ctrl 键。
17. 怎样快速的打开页面?
1. 禁止或精简弹出窗口及内容过滤列表。
2. 禁止或精简状态栏的显示内容: 本地 IP 地址、空闲物理内存、网络速率、Modem 速率。
18. 怎样解除网页的鼠标左右键限制?
一些网页锁定了鼠标左右键的文本选择和点击的功能,您可以解除这个限制:
1. 运行脚本插件“解除鼠标左右键限制”或在脚本收集器中运行这个脚本。
2. 禁止页面下载控制中的 Script,重新载入页面。
19. 怎样快速的找到具有相同或相似地址的标签?
有时候,您打开了很多页面,要从中寻找出地址相同或相似的标签就很困难。您可以使用标记/不标记功能,当输入相似的地址时,您可以修改这个地址字符,GreenBrowser 就能找到相似的地址并用特殊的图标把它们标记出来。
20. 怎样快速的关闭一些标签?
1. 锁定标签,点击“全部关闭”。
2. 如果网页的地址相同或相似,点击“全部关闭(相似地址)”。
3. 如果网页的标题相同或相似,点击“全部关闭(相似标题)”。
4. 您可以快速关闭在当前页左、右侧的所有页面。
21. 怎样禁止显示 Flash?
1. 添加 *.swf 到页面内容过滤列表,同时开启页面内容过滤功能。
2. 在“页面下载控制”菜单中不选择“显示 Flash(所有窗口)”,这个方法比第一个方法的效率可能更高,但这将禁止所有 IE 内核浏览器显示 Flash。
22. 怎样使 GreenBrowser 更稳定?
GreenBrowser 支持脚本插件,但某些错误或复杂的脚本可能会导致 GreenBrowser 崩溃。建议谨慎运行脚本插件。
23. 怎样安装插件?
1. 通过 GreenBrowser 主页下载插件压缩包。
2. 将压缩包解压到一个新的文件夹下。
3. 点击 工具扩展工具栏设置扩展工具栏...
4. 点击 ”...“ 后选择插件,然后按下插入按钮。
5. 如果您把一些插件都放在一个文件夹下,您可以点击 “导入脚本插件...” 来选择这个文件夹,然后您就可以一次性导入该文件夹下的所有插件。
24. 怎样在浏览时保护页面标题信息?
1. 您可以选择 “禁止在窗口标题栏中显示网页标题”。
2. 您可以为页面标签分配固定标题,如果您需要将固定标题分配给所有标签,就在点击 “确定“ 前按住 Shift 键。
25. 怎样快速的删除地址栏和搜索栏关键字条目?
1. 您可以下拉列表并使用 “Delete” 键直接删除条目。
2. GreenBrowser 选项中的删除选项。
26. 怎样禁止网页弹出关于ActiveX认证的对话框?
有两种方法:
1.使用外部工具 NotTroubleMe 别烦我,将您不想弹出的ActiveX对话框的CLSID添加到 NotTroubleMe 并选中该项。
2.在内容过滤列表中添加规则“*.cab”,并启用页面内容过滤器。
27. 怎样使用GreenBrowser的相对路径?
如果您想使用GreenBrowser安装路径下的目录或文件,只需要在其路径前面添加“.”或者“..”,例如: .skin, .Proxy.ini, . esource esource.htm,..Software.
J. Java访问指定URL并获取网页源代码
1.编写 类的基本框架,该类仅包括无返回值的main ()方法,该方法从参数中获取URL,通过输入缓冲和输出缓冲将该URL 原码输出。
2.编写useSourceViewer 类,代码如下:
import java.net.*;
import java.io.*;
public class useSourceViewer
{
public static void main (String[] args)
{
if (args.length > 0)
{
try
{
//读入URL
URL u = new URL(args[0]);
InputStream in = u.openStream( );
// 为增加性能存储输入流
in = new BufferedInputStream(in);
// 将输入流连接到阅读器
Reader r = new InputStreamReader(in);
int c;
while ((c = r.read( )) != -1)
{
System.out.print((char) c);
}
Object o = u.getContent( );
System.out.println("I got a " + o.getClass().getName( ));
}
catch (MalformedURLException e)
{
System.err.println(args[0] + " is not a parseable URL");
}
catch (IOException e)
{
System.err.println(e);
}
} // end if
} // end main
} // end SourceViewer}