平常最多的需求是将baidu.com指向全域名www.badu.com,但是往往需求是各种各样,这两天就遇到一个反向需求。将baidu.com直接访问网站,而不做跳转。

最近两天在给域名证书续费,但是需要外国证书认证机构给域名注册时留的邮箱发邮件确认,发了几次邮件,仍然没有收到邮件。于是,协商决定在网站下面放一个认证码,让国外访问来确定域名归属。

以下把我在配置过程中遇到的问题总结如下:

1、tomcat下新建目录下文件访问404

接到这个问题,想着很简单,在站点目录下面创建一个文件,然后全路径访问就好了,但是当真的这么做了以后,才发现事情并没有那么简单,检查过权限啊,重启啊,总是404.然后网上查资料,各种回答都有,有的说把web.xml放到新建目录下,照做后,问题

仍然没有解决。咨询了开发后,才知道开发在springMVC.xml下配置了启动tomcat后加载的资源和要拦截的地址(目录地址)。比如我要访问www.baidu.com/.well-known/1.txt,那么我就要在springMVC.xml下添加下面两行内容:

    <!-- 自动扫描controller包下的所有类,使其认为spring mvc的控制器 -->
<context:component-scan base-package="com.hengxin.qianee.controller" /> <mvc:annotation-driven /> <mvc:resources mapping="/css/**" location="/css/" />
<mvc:resources mapping="/images/**" location="/images/" />
<mvc:resources mapping="/js/**" location="/js/" />
<mvc:resources mapping="/skippr/**" location="/skippr/" />
.......
<mvc:resources mapping="/sitemap.txt" location="/" />
<mvc:resources mapping="/sitemap.xsl" location="/" />
<mvc:resources mapping="/silian.txt" location="/" />
<mvc:resources mapping="/.well-known/**" location="/.well-known/" />
<mvc:interceptors>
<!-- 使用bean定义一个Interceptor,直接定义在mvc:interceptors根下面的Interceptor将拦截所有的请求 -->
<mvc:interceptor>
<mvc:mapping path="/**"/> <!-- 需排除拦截的地址 -->
<mvc:exclude-mapping path="/.well-known/**"/>
<mvc:exclude-mapping path="/css/**"/>
<mvc:exclude-mapping path="/images/**"/>
<mvc:exclude-mapping path="/js/**"/>
<mvc:exclude-mapping path="/skippr/**"/>
<mvc:exclude-mapping path="/account/getCity"/>
<mvc:exclude-mapping path="/account/getAreas"/>

2、使用baidu.com直接访问网站。

原本网站做的跳转,如果输入baidu.com的时候自动跳转到www.baidu.com,但是现在认证方需要实现不要直接跳转,而是直接访问baidu.com/.well-known/1.txt,获取到认证方发来的认证码(这个认证码是事先发过来的,只要放到这个1.txt中即可),而我们网站做的多层跳转,如下图:

配置文件如下:

     server
{
listen ;
proxy_set_header Host $http_host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
server_name www.baidu.com; location ^~/front/aboutUs/aboutUs/
{
proxy_pass http://baidu;
} location /
{
rewrite ^(.*) https://www.baidu.com$1 permanent;
}
} server
{
listen ;
proxy_set_header Host $http_host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
server_name baidu.com; location ^~/front/aboutUs/aboutUs/
{
proxy_pass http://baidu;
}
rewrite ^(.*) http://baidu.com$1 permanent; } server
{
listen ;
proxy_set_header Host $http_host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
server_name www.baidu.com;
ssl on;
ssl_certificate /data/src/baidu.crt;
ssl_certificate_key /data/src/baidu.key;
ssl_session_timeout 5m;
ssl_protocols TLSv1 TLSv1. TLSv1.; location ^~/front/aboutUs/aboutUs/
{
rewrite ^(.*) http://www.baidu.com$1 permanent;
} location /
{
proxy_pass http://baidu;
}
} server
{
listen ;
ssl on;
proxy_set_header Host $http_host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
server_name baidu.com;
ssl_certificate /data/src/baidu.crt;
ssl_certificate_key /data/src/baidu.key;
ssl_session_timeout 5m;
ssl_protocols TLSv1 TLSv1. TLSv1.;
rewrite ^(.*) https://www.baidu.com$1 permanent; location /
{
proxy_pass https://baidu;
}
}

nginx.conf

本来想把其中的baidu.com的跳转给取消掉,结果,测试结果显示跳转太多,无法显示;然后又想把443的跳转和其他的多余的跳转都注销掉,测试结果显示了404,上述两种方法都否决了。

查阅了一番资料,仍然未果。

于是咨询了朋友,他们建议把80和443的虚拟主机配置上别名。但是仔细检查了下配置文件,心想即使配置上别名,仍然会将baidu.com跳转到www.baidu.com;但是仍然抱着破罐破摔的心态,决定尝试下,结果配置完后,居然成功了。

下面是配置过后的配置文件:

 server
{
listen ;
proxy_set_header Host $http_host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
server_name www.baidu.com baidu.com; location ^~/front/aboutUs/aboutUs/
{
proxy_pass http://baidu;
} location /
{
rewrite ^(.*) https://www.baidu.com$1 permanent;
}
} server
{
listen ;
proxy_set_header Host $http_host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
server_name www.baidu.com baidu.com;
ssl on;
ssl_certificate /data/src/baidu.crt;
ssl_certificate_key /data/src/baidu.key;
ssl_session_timeout 5m;
ssl_protocols TLSv1 TLSv1. TLSv1.; location ^~/front/aboutUs/aboutUs/
{
rewrite ^(.*) http://www.baidu.com$1 permanent;
} location /
{
proxy_pass http://baidu;
}
}

注:以上网站网址baidu.com是化名,并非真正网站网址。为保护网站信息,借用而已。

baidu.com直接访问网站,不跳转www.baidu.com的更多相关文章

  1. 通过PHP自带的$_SERVER判断 手机访问网站自动跳转到手机版

    需要有PC版网站和移动版网站,当手机访问域名的时候,通过PHP自带的$_SERVER判断浏览设备并跳转到移动版页面.如果是PC电脑打开网址,则不跳转直接访问pc版. <?php //php判断客 ...

  2. 通过cookies跳过验证码登陆页面,直接访问网站的其它URL

    我每次手动访问去NN网的一家酒店,就不需要登陆,一旦我用脚本打开就会让我登陆,而登陆页面又有验证码,不想识别验证码,所以就想:“通过cookies跳过验证码登陆页面,直接访问网站的其它URL”   转 ...

  3. 手机访问PC网站自动跳转到手机网站代码(转)

    4G时代,手机网站已经非常普遍了,一般手机网站都有一个二级域名来访问,比如 m.16css.com 如果手机直接访问www.16css.com 就是PC网站,在手机上浏览电脑版网站体验非常不好. 如果 ...

  4. 手机访问PC网站自动跳转到手机网站代码

    方法一: <script type="text/javascript"> try { var urlhash = window.location.hash; if (! ...

  5. dede手机访问网站跳转到手机端模板

    如何手机访问的时候跳转到自己的手机端模板,这时候需要一个js跳转代码:当手机访问的时候直接跳转到手机端 那手机端前提要有手机端的模板 <script> if(navigator.platf ...

  6. js判断是手机还是电脑访问网站

    js判断是手机还是电脑访问网站                               <script type="text/javascript"> <!- ...

  7. htaccess文件还可以被用来把访问网站的流量劫持到黑客的网站

    看是否有文件上传操作(POST方法), IPREMOVED--[01/Mar/2013:06:16:48-0600]"POST/uploads/monthly_10_2012/view.ph ...

  8. Nginx禁止直接通过IP地址访问网站以及限制IP登陆某目录(关闭默认站点或空主机头)

    这篇文章主要介绍了Nginx中禁止使用IP访问网站的配置实例,一般在备案时可能需要这种设置,需要的朋友可以参考下   国内因为备案的原因,所有服务器都要禁止使用IP访问网站.否则,如果允许使用IP访问 ...

  9. Nginx禁止直接通过IP地址访问网站

    介绍下在nginx服务器禁止直接通过IP地址访问网站的方法,以避免别人恶意指向自己的IP,有需要的朋友参考下. 有时会遇到很多的恶意IP攻击,在Nginx下可以禁止IP访问. Nginx的默认虚拟主机 ...

随机推荐

  1. C++ 保存Excel文件(带密码保护)

    最近有客户需求报表保存为xls的功能,需要保存的文件设置密码保护,特进行尝试! Workbook.SaveAs method (Excel) 参数详情:https://docs.microsoft.c ...

  2. js将json数据以csv格式下载

    摘要: 最近有一个非项目的小需求,就是将项目开发分工文件化,方便后期管理维护.但是开发时,分工安排都是以json格式记录的,所以就做了一个将json数据以csv格式下载到本地. 代码: <!DO ...

  3. 探究Visual Studio生成的.vs文件夹内部结构和作用

    https://shiyousan.com/post/636441130259624698 在某个契机的引发下,对VS解决方案中自动生成的.vs文件夹产生了兴趣,以前总对这个文件夹不怎么上心,最近正好 ...

  4. Java动态调用类中方法

    在Java中,调用类的方法有两种方式:对于静态方法可以直接使用类名调用,对于非静态方法必须使用类的对象调用.反射机制提供了比较另类的调用方式,可以根据需要指定要调用的方法,而不必在编程时确定.调用的方 ...

  5. 详解 Tomcat 的连接数与线程池(转)

    很不错的文章 https://juejin.im/post/5a0bf917f265da432d27a215

  6. Spring集成Mybatis,spring4.x整合Mybatis3.x

    Spring集成Mybatis,spring4.x整合Mybatis3.x ============================== 蕃薯耀 2018年3月14日 http://www.cnblo ...

  7. 使用 redis “捕捉” “用户登录过期” 事件

    实现原理及步骤: 1)登录时,计算登录过期时间,以分钟为单位作key(例如:sign_timeout_201705212233),value方面自己发挥,需要什么数据就拼什么数据进去,只是要注意,一定 ...

  8. Data Guard启动实时日志应用

    1. REDO数据实时应用 启动实时应用的优势在于,REDO数据不需要等待归档完成,接收到即可被应用,这样执行角色切换时,操作能够执行得更快,因为日志是被即时应用的. 要启动实时应用也简单,前提是St ...

  9. Weblogic CVE-2018-2894 漏洞复现

    0x01 前言 Oracle官方发布了7月份的关键补丁更新CPU(Critical Patch Update),其中针对可造成远程代码执行的高危漏洞 CVE-2018-2894 进行修复:http:/ ...

  10. std::string与std::wstring互相转换

    作者:zzandyc来源:CSDN原文:https ://blog.csdn.net/zzandyc/article/details/77540056 版权声明:本文为博主原创文章,转载请附上博文链接 ...