WEB项目后端跨域请求

简介: using System; using System.Collections.Generic; using System.IO; using System.Linq; using System.
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Net;
using System.Text;
using System.Web;
using System.Web.SessionState;

namespace GL
{
    public class CrossDomainHandler:IHttpModule, IRequiresSessionState
    {
        /// <summary>
        /// 释放内存
        /// </summary>
        public void Dispose()
        {
        }

        /// <summary>
        /// 开始请求
        /// </summary>
        /// <param name="context"></param>
        public void Init(HttpApplication context)
        {
            //页面开始请求时,绑定时间
            context.BeginRequest += new EventHandler(context_PreRequestHandlerExecute);
        }

        /// <summary>
        /// 请求处理
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        void context_PreRequestHandlerExecute(object sender, EventArgs e)
        {

            HttpApplication app = (HttpApplication)sender;
            HttpContext context = app.Context;

            context.Response.AppendHeader("charset", "utf-8");
            context.Response.AppendHeader("defaultCharset", "utf-8");
            context.Response.AppendHeader("Content-Type", "text/html; charset=utf-8");

            var relativeAddr = context.Request.AppRelativeCurrentExecutionFilePath.Remove(0, 2);
            if (relativeAddr.StartsWith("Server")) 
            {
                var url = string.Concat("http://localhost:89", relativeAddr.Substring(relativeAddr.IndexOf('/')));
                HttpWebRequest request = WebRequest.Create(url) as HttpWebRequest;
                request.Method = "POST";
                request.ContentType = "application/x-www-form-urlencoded";
                var rs = request.GetRequestStream();
                var sb = new StringBuilder("a=a&");
                context.Request.Form.AllKeys.ToList().ForEach(name =>
                {
                    sb.AppendFormat("{0}={1}&", name, context.Request.Form[name]);
                });
                var str = sb.ToString();
                if(str.Contains('&'))
                {
                    str = str.Substring(0, str.Length - 1);
                }
                var sw = new StreamWriter(rs, Encoding.UTF8);
                sw.Write(sb.ToString());
                sw.Close();

                request.Timeout = 60 * 1000;
                var response = request.GetResponse() as HttpWebResponse;
                var ps = response.GetResponseStream();
                var reader = new StreamReader(ps, Encoding.UTF8);
                string html = reader.ReadToEnd();
                ps.Close();
                context.Response.Write(html);
                context.Response.End();
            }
        }
    }
}

  

目录
相关文章
|
25天前
|
存储 安全 关系型数据库
后端技术:构建高效稳定的现代Web应用
【10月更文挑战第5天】后端技术:构建高效稳定的现代Web应用
46 1
|
6天前
|
JavaScript 前端开发 数据安全/隐私保护
Web开发者必看:手把手教你如何轻松播放m3u8流地址,解锁视频播放新技能,让你的项目更上一层楼!
【10月更文挑战第23天】随着互联网技术的发展,m3u8格式因良好的兼容性和高压缩率被广泛用于网络流媒体传输。本文介绍如何在Web端播放m3u8流地址,包括引入视频播放器(如Video.js)、创建播放器容器、初始化播放器及播放m3u8流的具体步骤。此外,还涉及处理加密m3u8流的示例。
13 1
|
15天前
|
JSON 搜索推荐 API
Python的web框架有哪些?小项目比较推荐哪个?
【10月更文挑战第15天】Python的web框架有哪些?小项目比较推荐哪个?
37 1
|
16天前
|
存储 安全 数据库
后端技术在现代Web开发中的实践与创新
【10月更文挑战第13天】 本文将深入探讨后端技术在现代Web开发中的重要性,通过实际案例分析展示如何利用先进的后端技术提升用户体验和系统性能。我们将从基础架构设计、数据库优化、安全性保障等方面展开讨论,为读者提供清晰的指导和实用的技巧。无论是新手开发者还是经验丰富的技术人员,都能从中获得启发和帮助。
29 2
|
19天前
|
自然语言处理 Cloud Native 数据安全/隐私保护
后端技术在现代Web开发中的实践与创新
本文探讨了后端技术在现代Web开发中的重要性及其应用。通过分析当前流行的后端框架和开发模式,揭示了如何利用这些技术来构建高效、可扩展的Web应用程序。同时,文章也讨论了未来后端技术的发展趋势,为开发者提供了一些启示。
|
22天前
|
算法 Java Linux
java制作海报五:java 后端整合 echarts 画出 折线图,项目放在linux上,echarts图上不显示中文,显示方框口口口
这篇文章介绍了如何在Java后端整合ECharts库来绘制折线图,并讨论了在Linux环境下ECharts图表中文显示问题。
36 1
|
29天前
|
前端开发 JavaScript API
惊呆了!学会AJAX与Fetch API,你的Python Web项目瞬间高大上!
在Web开发领域,AJAX与Fetch API是提升交互体验的关键技术。AJAX(Asynchronous JavaScript and XML)作为异步通信的先驱,通过XMLHttpRequest对象实现了局部页面更新,提升了应用流畅度。Fetch API则以更现代、简洁的方式处理HTTP请求,基于Promises提供了丰富的功能。当与Python Web框架(如Django、Flask)结合时,这两者能显著增强应用的响应速度和用户体验,使项目更加高效、高大上。
47 2
|
22天前
|
监控 Java Maven
springboot学习二:springboot 初创建 web 项目、修改banner、热部署插件、切换运行环境、springboot参数配置,打包项目并测试成功
这篇文章介绍了如何快速创建Spring Boot项目,包括项目的初始化、结构、打包部署、修改启动Banner、热部署、环境切换和参数配置等基础操作。
85 0
|
23天前
|
前端开发 Java Shell
后端项目打包上传服务器部署运行记录
后端项目打包上传服务器部署运行记录
23 0
|
29天前
|
前端开发 API 数据格式
颠覆传统!AJAX、Fetch API与Python后端,开启Web开发新篇章!
在Web开发领域,技术的快速迭代推动着应用不断进化。传统前后端交互方式已无法满足现代Web应用对高效、实时性和用户体验的需求。AJAX作为异步通信的先驱,使页面无需刷新即可更新部分内容,显著提升用户体验;尽管XML曾是其主要数据格式,但如今JSON已成为主流。Fetch API则以其简洁、灵活的特点成为AJAX的现代替代品,基于Promises的异步请求让开发更加高效。与此同时,Python后端凭借高效稳定和丰富的库支持,成为众多开发者的首选,无论是轻量级的Flask还是全功能的Django,都能为Web应用提供强大的支撑。
36 0