2015-02-13 09:45:24 iteye_4696 阅读数 176
  • Python网络爬虫基础篇

    本课程主要给大家分享基于Python语言的网络爬虫基础篇体验,其中讲解爬虫原理介绍,urllib和requests爬虫库的使用,以及网络爬虫中的数据分析与信息提取。通过模拟Web的GET和POST请求来爬取数据,介绍如何应对各种常见反爬机制。后续还会有更深入的网络爬虫介绍体验,请大家持续关注。

    8373 人正在学习 去看看 CSDN讲师
post提交数据有大小限制,如果是大数据提交的话会导致数据无法传输到后台,可以通过修改tomcat/conf/下面的server.xml文件信息

<Connector port="8080" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443"
maxPostSize="0"/>

增加maxPostSize="0",表示不受提交数据大小限制。
2019-11-10 10:34:36 STAR_TOWER 阅读数 12
  • Python网络爬虫基础篇

    本课程主要给大家分享基于Python语言的网络爬虫基础篇体验,其中讲解爬虫原理介绍,urllib和requests爬虫库的使用,以及网络爬虫中的数据分析与信息提取。通过模拟Web的GET和POST请求来爬取数据,介绍如何应对各种常见反爬机制。后续还会有更深入的网络爬虫介绍体验,请大家持续关注。

    8373 人正在学习 去看看 CSDN讲师

GET和POST长度的限制问题
GET
1.GET是通过URL提交数据,因此GET可提交的数据量就跟URL所能达到的最大长度有直接关系。
限制长度总结借鉴https://blog.csdn.net/zimuxin/article/details/78082747
2.实际上HTTP协议对URL长度是没有限制的;限制URL长度大多数是浏览器或者服务器的配置参数
POST
1.同样的,HTTP协议没有对POST进行任何限制,一般是受服务器配置限制或者内存大小。
GET和POST的安全性
1.GET是通过URL方式请求,可以直接看到,明文传输,不够安全。
2.POST是通过请求header请求,可以开发者工具或者抓包可以看到,同样也是明文的。 3.GET请求会保存在浏览器历史纪录中,还可能会保存在Web的日志中。
GET和POST对服务器的状态
根据http的设计,大家在看到get的时候,都期望这个请求对服务器没有修改,看到post的时候,都认为这对服务器产生了修改。
GET幂等,POST不幂等
幂等是指同一个请求方法执行多次和仅执行一次的效果完全相同。
1.按照RFC规范,PUT,DELETE和安全方法都是幂等的。虽说是规范,但服务端实现是否幂等是无法确保的。
2.引入幂等主要是为了处理同一个请求重复发送的情况,比如在请求响应前失去连接,如果方法是幂等的,就可以放心地重发一次请求。这也是浏览器在后退/刷新时遇到POST会给用户提示的原因:POST语义不是幂等的,重复请求可能会带来意想不到的后果。
3.比如在微博这个场景里,GET的语义会被用在「看看我的Timeline上最新的20条微博」这样的场景,而POST的语义会被用在「发微博、评论、点赞」这样的场景中。

2018-03-25 18:10:54 GorgeousChou 阅读数 124
  • Python网络爬虫基础篇

    本课程主要给大家分享基于Python语言的网络爬虫基础篇体验,其中讲解爬虫原理介绍,urllib和requests爬虫库的使用,以及网络爬虫中的数据分析与信息提取。通过模拟Web的GET和POST请求来爬取数据,介绍如何应对各种常见反爬机制。后续还会有更深入的网络爬虫介绍体验,请大家持续关注。

    8373 人正在学习 去看看 CSDN讲师

在编写表单时,有两种方法,分别是GET和POST,定义传输格式的表单语句为<form method="GET/POST">

两种传值方法的特点:
- 参数是否会显示在地址栏上:使用GET方法参数会显示在地址栏上,而POST不会
- 传输的数据量大小:GET传输的数据量最大2K左右,这个取决于使用的web服务器和服务器的配置;POST可传输的数据量理论上没有上限,但是数据量过大时会产生超时的错误
- 上传文件必须使用POST方法

在PHP中分别使用$_GET和$_POST这两个超级全局变量来接收浏览器表单使用GET方法和POST方法传过来的数据,这两个变量都是数组。数组中的元素的索引为在编写表单时定义的name=”NAME”,需要取出表单传给PHP的值,只需要使用$_GET[‘name’],其中’name’为表单中的name属性。

2013-09-13 20:28:26 helloliyewen 阅读数 660
  • Python网络爬虫基础篇

    本课程主要给大家分享基于Python语言的网络爬虫基础篇体验,其中讲解爬虫原理介绍,urllib和requests爬虫库的使用,以及网络爬虫中的数据分析与信息提取。通过模拟Web的GET和POST请求来爬取数据,介绍如何应对各种常见反爬机制。后续还会有更深入的网络爬虫介绍体验,请大家持续关注。

    8373 人正在学习 去看看 CSDN讲师



使用get请求会受到地址传输的限制,所以也可以使用post请求提交。

get请求与post请求的最大区别在于一个显示,一个不显示。

我的外网IP     192.168.1.13

 

 

配置tomcat服务器:在我的电脑D盘新建一个虚拟目录liyewenweb,将tomcat中webapps\ROOT下

的WEB-INF目录复制到liyewenweb下,配置tomcat中conf下的server.xml ( 在后面<Host> </Host> 中

增加 <Context path="/liyewen" docBase="d:\liyewenweb"/> ), 配置tomcat中conf下的

web.xml ( 找到listings,并将下面的false改成true )。

 

 

 

 

 

在D盘liyewenweb目录下新建android.jsp,内容如下:

 

<% // 接收发送来的请求

  String id = request.getParameter("id") ;

  String password = request.getParameter("password") ;

%>

<%

  if ("xingming".equals(id) && "mima".equals(password)) {

%>

     true

<%

  } else {

%>

     false

<%

  }

%>

 

 

 

 

 

 

 

 

新建一个Android项目:

 

 

 

在main.xml中:

 

<?xml version="1.0" encoding="utf-8"?>

<LinearLayout

  xmlns:android="http://schemas.android.com/apk/res/android"

  android:orientation="vertical"

  android:layout_width="fill_parent"

  android:layout_height="fill_parent"

  android:background="#3399ff">

  <TextView

     android:id="@+id/info"

     android:gravity="center_horizontal"

     android:layout_marginTop="20dp"

     android:layout_width="fill_parent"

     android:layout_height="wrap_content"

     android:textColor="#ffffff"

     android:textSize="20dp"/>

</LinearLayout>

 

 

 

 

 

 

 

在MyWebDemo.java中:

 

package com.e.webproject;

 

import java.util.ArrayList;

import java.util.List;

 

import org.apache.http.HttpResponse;

import org.apache.http.NameValuePair;

import org.apache.http.client.entity.UrlEncodedFormEntity;

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 android.app.Activity;

import android.os.Bundle;

import android.widget.TextView;

 

public class MyWebDemo extends Activity {

  private TextView info = null;

  private static final String URL = "http://192.168.1.13/liyewen/android.jsp"; // 请求地址

 

  @Override

  public void onCreate(Bundle savedInstanceState) {

     super.onCreate(savedInstanceState);

     super.setContentView(R.layout.main);

     this.info = (TextView) super.findViewById(R.id.info);

     boolean flag = false; // 成功与否的标记

     try {

       HttpPost request = new HttpPost(URL);

       List<NameValuePair> params = new ArrayList<NameValuePair>();

       params.add(new BasicNameValuePair("id", "xingming"));

       params.add(new BasicNameValuePair("password", "mima"));

       request.setEntity(new UrlEncodedFormEntity(params, HTTP.UTF_8));

       HttpResponse response = new DefaultHttpClient().execute(request);

       if(response.getStatusLine().getStatusCode() != 404) {  // 现在已经发现了数据了

         flag = Boolean.parseBoolean(EntityUtils.toString(

              response.getEntity()).trim());

       }

     } catch (Exception e) {

       info.setText("WEB服务器连接失败!");

     }

     if (flag) {

       info.setText("用户李叶文登录成功!");

     } else {

       info.setText("用户登录失败!");

     }

  }

}

 

 

 

 

 

在AndroidManifest.xml中配置权限:

 

<manifest xmlns:android="http://schemas.android.com/apk/res/android"

    package="com.e.webproject"

    android:versionCode="1"

    android:versionName="1.0" >

 

    <uses-sdk

        android:minSdkVersion="8"

        android:targetSdkVersion="15" />

  <uses-permission android:name="android.permission.INTERNET" />

    <application

        android:icon="@drawable/ic_launcher"

        android:label="@string/app_name"

        android:theme="@style/AppTheme" >

        <activity

            android:name=".MyWebDemo"

            android:label="@string/title_activity_my_web_demo" >

            <intent-filter>

                <action android:name="android.intent.action.MAIN" />

 

                <category android:name="android.intent.category.LAUNCHER" />

            </intent-filter>

        </activity>

    </application>

 

</manifest>

 

2016-06-14 14:47:35 u011349860 阅读数 124
  • Python网络爬虫基础篇

    本课程主要给大家分享基于Python语言的网络爬虫基础篇体验,其中讲解爬虫原理介绍,urllib和requests爬虫库的使用,以及网络爬虫中的数据分析与信息提取。通过模拟Web的GET和POST请求来爬取数据,介绍如何应对各种常见反爬机制。后续还会有更深入的网络爬虫介绍体验,请大家持续关注。

    8373 人正在学习 去看看 CSDN讲师

整理出POST与GET 区别并罗列于此:

  • 安全性:

GET传输的数据可见,安全性较差。

  • 传输数据的容量:

GET传输量受URL最大长度限制,而HTTP协议并未规定URL最大长度,一般受限于浏览器、服务器或者操作系统的相关设置,IE的最大URL长度为2083,即2K+35,火狐一般没有限制;当浏览器不限制时,服务器、操作系统等会限制最大URL。

POST传输量一般不受限制。

  • 支持的数据类型
发送中文时可能出错,需要使用urlEncode()编码后传输
  • 收藏

GET支持收藏,POST不支持

  • 刷新

POST刷新时浏览器会提示“重复提交数据”。

  • 历史

GET的数据会被保存在浏览器的浏览历史里

get与post的区别

阅读数 20

没有更多推荐了,返回首页