其他教程
模板兔提供一些网站建设相关的教程,让大家迅速的做好一个网站。
思路:小程序登录获取到openId后通过微信的回调地址传参、再走微信公众号的通过code获取openId授权。
获取小程序openId并传入H5
1、小程序openId通过webView地址传参
2、判断环境
3、公众号跳转判断
比如我们直接访问/aaa.mp4路径时是直接播放视频,如果加了一个参数download=1(也就是直接访问/aaa.mp4?download=1)就是直接下载视频。
可以在宝塔里设置站点的配置文件,加上以下代码
location ~ .*\.(mp3|wma|mp4|swf|txt)$
{
if ( $query_string ~ "download=1$" )
{
charset utf-8,gbk;
add_header Content-Disposition "attachment; filename*=$arg_n";
}
}
本文介绍如何在小程序中内嵌H5,并完成微信支付的整个流程闭环。我们知道微信H5支付是通过生成特定的支付链接,并跳转到这个链接去完成支付操作的。但在微信小程序中对于内嵌的页面域名具有白名单限制,如果支付链接是第三方的无法做加白处理。
这个时候我们就得换个思路了,该怎么解决呢?咱们往下看。
实现过程
小程序入口
在微信小程序中新建一个页面,使用web-view组件作为内嵌H5的入口,由于后续支付需要用到appId以及openId信息,因此需要对url做带参做处理
// page.wxml
<web-view src="{{url}}"></web-view>
url处理逻辑:
Page({
data: {
url: ''
},
onLoad: function (options) {
wx.sh...
最近模板兔给一个客户做Ai绘画小程序,需要用到自动翻译,一开始用百度的接口,但是但是百度接口在某种情况下有Bug,所以转用了阿里云的接口,下面简单说一下如何使用阿里云机器翻译API。
SDK安装
composer require alibabacloud/sdk
比如你的项目目录是app,那么可以在宝塔里对app目录进行composer安装,安装完成后会自动生成一个vendor文件夹,然后接着引用即可。
Github地址是github.com/aliyun/openapi-sdk-php
代码示例
require __DIR__ . '/vendor/autoload.php';
use AlibabaCloud\Client\AlibabaCloud;
use AlibabaCloud\Client\Exception\ClientException;
use AlibabaCloud\Client\Exception\ServerException;
re...
最近模板兔给客户做了一个功能就是对海外用户价格翻倍,那么我们如何判断是海外用户呢?
这里,我们可以通过一个IP获取归属地的接口来简单判断下,但是这样判断可能会导致网络卡顿。
$ip = mbt_get_ip();
$api = "http://sp0.baidu.com/8aQDcjqpAAV3otqbppnN2DJv/api.php?query=".$ip."&co=&resource_id=6006";
$result = get_url_contents($api);
$result= iconv('GB2312', 'UTF-8', $result);
$result = json_decode($result,true);
if($result['status'] == '0'){
$loct = $result['data'][0]['location'];
//echo $loct;
if(strpos($loct,'北京')!==false || strpos($loct,'上海')!==false || strpos($loct,'天津')...
我们可以通过 jsDelivr 来自建CDN加速。它很强大,通过 GitHub 搭配 jsDelivr 可以搭建自己专属的 CDN 库。
接下来将介绍 jsDelivr 与 GitHub 如何搭配使用。
首先,登录 GitHub 账户,创建新的仓库,仓库名为 cdn 。
然后,将仓库下载下来,添加静态资源文件,模板兔添加了 jquery.min.js 文件,然后上传到远程仓库。
GitHub 仓库界面,点击 tag => Releases ,发布版本。
此时,我们通过如下 url 规则即可访问刚才发布的资源了:
https://cdn.jsdelivr.net/gh/<GitHub 用户名>/<GitHub 仓库名>@<发布的版本号>/<文件路径>
https://cdn.jsdelivr.net/gh/erphp/cdn@1.0/jquery.min.js
其...
我们在做js开发的时候会遇到使用layer框架来做弹窗处理,那么在iframe子窗口处理完逻辑后想自动关闭子窗口(不刷新父窗口)并传值给父窗口,该如何做呢?下面模板兔给出相关代码供参考。
子窗口的代码:
window.parent.erphpdownKeySuccess(data.html);
var index = parent.layer.getFrameIndex(window.name);
parent.layer.close(index);
父窗口的代码:
function erphpdownKeySuccess(shtml){
jQuery(".erphpdown-key-result").html(shtml);
var clipboard_pop = new Clipboard(".pop-copy");
clipboard_pop.on("success", function(e) {
layer.msg("已复制关键字",{time:500});
});
}
想必很多用户都遇到自己的wordpress网站数据库挂掉的情况吧,因为内存经常不足导致宝塔面板mysql经常停止,需要检测mysql进程是否停止,就像php守护程序一样,检测到mysql 进程禁止后,检测到mysql停止会自动启动。
那么如何在数据库挂掉的时候自动重启数据库呢?
Mysql进程守护脚本 shell脚本一:
pgrep -x mysqld &> /dev/null
if [ $? -ne 0 ];then
bash /www/server/panel/script/rememory.sh
/etc/init.d/mysqld start
fi
Mysql进程守护脚本 shell脚本二:
#!/bin/bash
PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:~/bin
export PATH
pgrep -x mysqld &> ...
CloudFlare 的缓存可以提高网站的访问速度,但有时也会带来一些管理上的麻烦。好在,CloudFlare 允许禁用缓存。
CloudFlare 没有直接的配置项可以禁用缓存,但它提供了 Page Rule。
使用 Page Rule 完全禁用缓存:
erphpdown.com/*
*.erphpdown.com/*
添加两条规则,都选择 Cache Level(缓存规则),值为 ByPass(绕过)。
最后不要忘了在 Caching 面板中,Purge Cache 清除所有缓存。
这样就禁用了你整个网站的缓存了。
swiper幻灯片窗口大小变化以及container容器宽度变化时会导致图片宽度与容器宽度不一样,出现错乱,经过一番查询,可以在swiper的初始化里加以下代码
resizeObserver: true, //窗口容器变化
on: {
resize: function(){
this.update(); //窗口变化时,更新Swiper的一些属性,如宽高等
},
}
但是,这个代码仅对浏览器窗口变化有效,container容器大小变化时无效,那么怎么解决呢?
可以动态获取容器的宽度,修改容器的宽度,但是我们不能直接获取容器的宽度,只能通过窗口的宽度减去其他div的宽度,计算出最新的容器的宽度。
var ddd = window.innerWidth - 90 - $(".sidebar-left").width();
swiperHome.el.style.width = ddd+'px'...
最近开发时遇到一个很奇怪的问题,swiper轮播时第二张开始会往左偏移,一开始我以为是宽度没100%,设置后也没用,百思不得其解。
最后找到了解决方案:
var swiper = new Swiper('.swiper-container', {})中添加
observer: true, // 修改swiper自己或子元素时,自动初始化swiper
observeParents: true, // 修改swiper父元素时,自动初始化swiper
这样就解决了!
PHP的array_filter函数,通过array_filter可以在数组中查找value
<?php
// 定义一个二维数组
$arr = array(
array('id'=>2, 'score'=>103),
array('id'=>5, 'score'=>102),
array('id'=>3, 'score'=>102),
array('id'=>3, 'score'=>107),
array('id'=>4, 'score'=>101),
);
/*********** 在二维数组中通过value查找数组元素 ***********/
$searchValue = 102;
$r = array_filter($arr, function($t) use ($searchValue) { return $t['score'] == $searchValue; });
var_dump($r);
/******************** 查找end ********************/
?>
本文实例为大家分享了JavaScript实现无缝滚动图片的具体代码,供大家参考,具体内容如下:
参数说明:
setInterval 开启间隔型定时器
clearTimeout 关闭定时器
offsetWidth 获取宽度
offsetLeft 获取向左偏移量
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>无缝移动</title>
<style>
*{margin: 0; padding: 0;}
#div1{width:520px; height:170px; margin:20px auto; position: relative; /* !!! div1 的位置是相对的 */
background: pink; overflow: hidden} /* !!! overflow: hidden */
#div1 ul{position: absolute; left:0; top:0;} ...
checkbox/ radoi默认不支持更改背景颜色,这里可以使用伪类来实现。基本原理是利用after/ before插入新的元素。然后利用新元素的背景颜色或背景图片覆盖掉原来的样式。
input[type=checkbox] {
margin-right: 5px;
cursor: pointer;
font-size: 14px;
width: 15px;
height: 12px;
position: relative;
}
input[type=checkbox]:after {
position: absolute;
width: 10px;
height: 15px;
top: 0;
content: " ";
background-color: #ff0000;
color: #fff;
display: inline-block;
visibility: visible;
padding: 0px 3px;
border-radius: 3px;
}
input[type=checkbox]:checked:after {
content: "✓";
font-size: 1...
这里提供宝塔官方论坛的一键脚本安装,但是安装过程也非常漫长,慢慢等吧。
wget http://download.bt.cn/install/ext/ffmpeg.sh && sh ffmpeg.sh
安装完后可输入以下命令是否安装成功。
ffmpeg -version
3、网站应用
应用到网站需要在PHP×设置中取消掉 scandir,exec、system、shell_exec函数。
装好之后,PHP截图某一帧代码:
exec('/usr/local/bin/ffmpeg -ss 00:00:01 -i ./test.mp4 ./test.jpg -r 1 -vframes 1 -an -f mjpeg 1>/dev/null');
PHP代码示例:
function ffmpeg_thumb_callback(){
global $wpdb;
$post_id = esc_sql($_POST['post_id']);
$video = esc_sql($_POST['video']);
$status = 0;
...