safari浏览器访问问题

打开自己的网站访问日志,发现出现很多404的地址,地址分别都是这2个:

1)http://www.zbphp.com/apple-touch-icon.png

2)http://www.zbphp.com/apple-touch-icon-precomposed.png


搜索了一下关键字:apple-touch-icon.png,apple-touch-icon-precomposed.png,果然是Safari浏览器访问的。

解决方法,制作2张图片。apple-touch-icon.png 尺寸72x72、apple-touch-icon-precomposed.png 尺寸72x72

默认为57x57。图片格式:png。最佳尺寸:57x57。图片无需做圆角处理,同Native App一样,系统会自动为图标添加圆角及高光。



各尺寸自适应代码:

默认:57x57,iPad:72x72,iPhone 4,Retina屏:114x114(原尺寸的2倍)

  1. <linkrellinkrel="apple-touch-icon"href="apple-touch-icon-iphone.png"/>  
  2. <linkrellinkrel="apple-touch-icon"sizes="72x72"href="apple-touch-icon-ipad.png"/>  
  3. <linkrellinkrel="apple-touch-icon"sizes="114x114"href="apple-touch-icon-iphone4.png"/>  



只要做好相应尺寸的代码,加到页面里面就可以每个主屏幕上都会完美显完美!(来自: 免费PHP空间 www.zbphp.com)
### 禁止 Safari 浏览器访问网站或资源的方法 可以通过多种方式来阻止特定浏览器(如 Safari访问网站或资源。以下是几种常见的实现方法: #### 方法一:通过 User-Agent 判断并拒绝访问 大多数浏览器会在 HTTP 请求头中发送 `User-Agent` 字符串,用于标识客户端的身份。可以根据该字符串判断是否为 Safari 浏览器,并在服务器端拦截其请求。 ```python from flask import Flask, request, abort app = Flask(__name__) @app.route('/') def index(): user_agent = request.headers.get('User-Agent') if 'Safari' in user_agent and 'Chrome' not in user_agent: abort(403) # 返回 403 Forbidden 错误码 return "欢迎访问本网站" if __name__ == '__main__': app.run() ``` 上述代码片段展示了如何利用 Python 的 Flask 框架检测 `User-Agent` 并拒绝 Safari 访问[^1]。 #### 方法二:使用 JavaScript 阻止页面加载 如果希望在客户端层面阻止 Safari 用户访问,可以借助 JavaScript 来完成此操作。以下是一个简单的例子: ```javascript <script> document.addEventListener("DOMContentLoaded", function () { var isSafari = /^((?!chrome|android).)*safari/i.test(navigator.userAgent); if (isSafari) { alert("您的浏览器不受支持,请更换其他浏览器尝试!"); window.location.href = "about:blank"; // 将用户重定向至空白页或其他提示页 } }); </script> ``` 这种方法适用于轻量级场景,但由于它依赖于客户端执行脚本,因此可能被绕过[^2]。 #### 方法三:基于 Web Server 配置屏蔽 Safari 对于 Apache 或 Nginx 这样的主流 Web 服务器,可以直接在其配置文件中设置规则以屏蔽 Safari 浏览器。 ##### Nginx 示例: 编辑 Nginx 配置文件,添加如下内容: ```nginx server { listen 80; server_name example.com; location / { if ($http_user_agent ~* "(?=.*Safari)(?!.*Chrome)") { return 403; # 返回 403 Forbidden 响应 } root /var/www/html; index index.html; } } ``` 重启 Nginx 后生效。这种方式更加高效且难以规避[^3]。 #### 方法四:强制限定访问来源 除了直接禁止某些浏览器外,还可以规定只有来自指定设备或应用的流量才能正常浏览网页。例如,仅允许微信内置浏览器访问链接时可采用以下方案: ```php <?php $ua = strtolower($_SERVER['HTTP_USER_AGENT']); if(stripos($ua,'micromessenger') === false){ die('非法访问'); }else{ echo '欢迎使用微信内置浏览器访问'; } ?> ``` 这是一段 PHP 脚本示例,能够有效过滤掉非微信环境下的请求[^4]。 --- ### 总结 以上介绍了四种不同的技术手段用以限制 Safari 对目标站点的访问权限。实际部署过程中需综合考虑安全性需求以及用户体验等因素做出最佳选择。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值