三、伪造Referrer、增加中间页空白跳转

业务需求:在接入一个第三方支付时,基本流程是生产一个订单,然后后端返回一个URL用浏览器打开,之后就是打开原生的微信或支付宝支付,但其中一家支付厂商的支付URL有个特殊的要求,就是在浏览器发起请求时要设置Referrer这个请求头,但当前这个请求本身是第一次请求,浏览器默认是的referrer事空的,必须要在客户端自己想办法加上。

请求Referrer的地址,使用NSURLProtocol拦截WebView的这个请求并构造一个本地数据中转,通过这个中转再跳转到目标地址,代码如下:

亲测使用有效

目标地址:https://www.baidu.com 要伪造的referrer地址:https://www.google.com

这两个地址在实际开发使用中需要根据需要做成参数动态使用

1、创建URLProtocol的子类

LHJumpProtocol.h

#import

@interface LHJumpProtocol : NSURLProtocol

@end

LHJumpProtocol.m

#import "LHJumpProtocol.h"

static NSString * const URLProtocolHandledKey = @"URLProtocolHandledKey_jump";

@interface LHJumpProtocol()

@property (nonatomic, strong) NSURLConnection *connection;

@end

@implementation LHJumpProtocol

/*

这个方法是决定这个 protocol 是否可以处理传入的 request 的如是返回 true 就代表可以处理,如果返回 false 那么就不处理这个 request 。

*/

+ (BOOL)canInitWithRequest:(NSURLRequest *)request

{

//看看是否已经处理过了,防止无限循环

if ([NSURLProtocol propertyForKey:URLProtocolHandledKey inRequest:request]) {

return NO;

}

NSString *url = request.URL.absoluteString;

// 只有请求的是中转的地址才处理

if ([url isEqualToString:@"https://www.google.com"]) {

return YES;

}

return NO;

}

/*

这个方法主要是用来返回格式化好的request,如果自己没有特殊需求的话,直接返回当前的request就好了。如果你想做些其他的,比如地址重定向,或者请求头的重新设置,你可以copy下这个request然后进行设置

*/

+ (NSURLRequest *)canonicalRequestForRequest:(NSURLRequest *)request

{

NSMutableURLRequest *mutableReqeust = [request mutableCopy];

// xxx 可以在这里对request进行相关的设置参数,重定向等处理

return mutableReqeust;

}

/**

该方法主要是判断两个请求是否为同一个请求,如果为同一个请求那么就会使用缓存数据。通常都是调用父类的该方法

*/

+ (BOOL)requestIsCacheEquivalent:(NSURLRequest *)a toRequest:(NSURLRequest *)b

{

return [super requestIsCacheEquivalent:a toRequest:b];

}

- (void)startLoading

{

NSMutableURLRequest *mutableReqeust = [[self request] mutableCopy];

//打标签,防止无限循环

[NSURLProtocol setProperty:@YES forKey:URLProtocolHandledKey inRequest:mutableReqeust];

// 虚拟一般网络请求时服务器返回的中转网页内容,这段网页数据的作用是告诉浏览器请求都带上referrer,并且会加载这段网页后自动跳转到目标地址去

NSString *targetUrl = @"http://www.baidu.com";

NSString *text = [NSString stringWithFormat:@"

",targetUrl,targetUrl];

// 将字符串转换成NSData数据

NSData *data = [text dataUsingEncoding:NSUTF8StringEncoding];

// 将数据构造成返回的response

NSURLResponse *response = [[NSURLResponse alloc] initWithURL:mutableReqeust.URL MIMEType:@"text/html" expectedContentLength:data.length textEncodingName:nil];

[self.client URLProtocol:self

didReceiveResponse:response

cacheStoragePolicy:NSURLCacheStorageNotAllowed];

[self.client URLProtocol:self didLoadData:data];

[self.client URLProtocolDidFinishLoading:self];

}

- (void)stopLoading

{

[self.connection cancel];

}

#pragma mark - NSURLConnectionDelegate

- (void) connection:(NSURLConnection *)connection didReceiveResponse:(NSURLResponse *)response {

[self.client URLProtocol:self didReceiveResponse:response cacheStoragePolicy:NSURLCacheStorageNotAllowed];

}

- (void) connection:(NSURLConnection *)connection didReceiveData:(NSData *)data {

[self.client URLProtocol:self didLoadData:data];

}

- (void) connectionDidFinishLoading:(NSURLConnection *)connection {

[self.client URLProtocolDidFinishLoading:self];

}

- (void)connection:(NSURLConnection *)connection didFailWithError:(NSError *)error {

[self.client URLProtocol:self didFailWithError:error];

}

2、在AppDelegate里注册protocol

#import "LHAppDelegate.h"

#import "LHJumpProtocol.h"

@interface LHAppDelegate ()

@end

@implementation LHAppDelegate

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {

// xxxx 其他启动处理

// 注册protocol

[NSURLProtocol registerClass:[LHJumpProtocol class]];

return YES;

}

@end

3、使用UIWebView发起请求

UIWebView *webView = [ [UIWebView alloc] iniwWithFrame:self.view.bounds];

// 这里请求的要是需要的referrer的地址,这样才能构造一个虚拟的referrer

NSURL *url = [NSURL URLWithString:@"http://www.google.com"];

NSURLRequest *request = [NSURLRequest requestWithURL:url]; [webView loadRequest:request];

php webview referer,WebView构造中间页自由设置Referrer相关推荐

  1. android创建webview,Android Webview总结

    这些都是曾经收集到的一些关于Webview的知识,有些工作中用到了,有些暂时还没有用到,这次统一整理下,希望对自己,对大家有所帮助.另外,欢迎大家补充(当然,有错也要指正呀,不胜感激),如果可以的话, ...

  2. android webview mailto,Webview email link (mailto)

    问题 I have a view and view the site has malito code to send email. When I open the link opens in an e ...

  3. android url webview,android - webview获取到当前页面的url

    android - webview获取到当前页面的url 2017-10-23 08:54 访问量: 2958 分类: 技术 使用 webview.getUrl() 即可. 可以完美返回  a.com ...

  4. android webview java_Android WebView Java和JS通信

    前言: Android开发中,经常使用WebView来加载网页,而和WebView进行交互全部通过Java和Js互相调用来完成的.这篇文章就主要学习这块的知识. 本示例中,主要解决以下问题: Java ...

  5. Android WebView(一) WebView详解

    WebView,在Android开发中,我们总是会遇到,它是Google封装的,使用WebKit渲染引擎加载显示网页.接下来,我们就详细看看WebView的介绍以及使用.如果你想了解WebView主要 ...

  6. 解决webview 刷新问题,返回刷新webview,webview 刷新不好使

    @Override protected void onResume() {super.onResume();if (webView != null) {webView.onResume();//恢复p ...

  7. android 无障碍 webview,Android WebView使用

    原标题:Android WebView使用 前言 Android内置webkit内核的高性能浏览器,而WebView则是在这个基础上进行封装后的一个 控件,WebView直译网页视图,我们可以简单的看 ...

  8. android swf webview,android webview播放swf文件

    今天做了一个通过webview播放flash的文件,以前一直以为可以使用videoview视频播放播放flash的东西,今天才发现不行,好像现在除了自己做一个flash播放器,就是用webview去加 ...

  9. Android WebView及WebView的神坑之旅

    WebView的一些神坑 最近在开发过程中遇到一个问题,主要是WebView页面,需要调用本地相机拍照及图库,遇到一系列的神坑,这里结合本人所查阅的资料给大家一一说明. 进入正题,首先来了解webvi ...

最新文章

  1. Vue2.0学习笔记一 :各种表达式
  2. 机器学习笔记:Adam
  3. 现代谱估计:多窗口谱
  4. docker desktop ubuntu镜像_「Docker」 - 镜像仓库
  5. C++最大数的幂 largest power实现算法(附完整源码)
  6. poj1419 Graph Coloring 最大独立集(最大团)
  7. 开到朝鲜的国产十元店,一年如何卖出190亿?
  8. 动态修改css 规则
  9. 《HelloGitHub》第 73 期
  10. Codeforces 754D. Fedor and coupons
  11. java 多人视频聊天_Java SE实现多人聊天室功能
  12. window PCL安装编译
  13. IOS音乐播放器代码
  14. 三维可视化常见的技术路线浅析
  15. 基于ERP的WMS系统解决方案
  16. python标准库os中用来列出_雨课堂答案在哪查,雨课堂2020试题及答案
  17. java上传图片怎么查看,Java上传图片并查看
  18. bootstrap 4 在VS中的使用
  19. 当知识图谱遇上推荐系统之DKN模型(论文笔记一)
  20. CSP(内容安全策略)防运营商劫持

热门文章

  1. VS2010连接MySql数据库时无法选择mysql database数据源
  2. 用java swing做连连看_java基于swing实现的连连看代码
  3. 【PHP发展史】PHP5.2 到 PHP5.6 中新增的功能详解
  4. 网络包排错指南-类linux 平台
  5. Android JNI使用方法
  6. JavaScript中Element与Node的区别,children与childNodes的区别
  7. css对各个浏览器兼容技巧
  8. IncrediBuild 加速原理
  9. 行程日志2010-03-16沙井一村(1)
  10. 【Vegas原创】重建Exchange 2007 OWA的虚拟目录