yii2使用邮箱组件发送邮件信息 yii\swiftmailer\Mailer

 


'mailer' => [
'class' => 'yii\swiftmailer\Mailer',
// send all mails to a file by default. You have to set
// 'useFileTransport' to false and configure a transport
// for the mailer to send real emails.
'useFileTransport' => false,
'transport' => [
'class' => 'Swift_SmtpTransport',
'host' => 'smtp.163.com',
'username' => '邮箱@163.com',
'password' => '密码',
'port' => '端口',
'encryption' => 'tls',//大多部分用的是ssl
],
'messageConfig'=>[
'charset'=>'UTF-8',
'from'=>['support@amztracker.com'=>'support']
],
],

 <?php namespace app\controllers;
use Yii;use yii\filters\AccessControl;
use yii\web\Controller;
class MailController extends Controller{    
 /*发送邮件*/ 
public function actionSend() {
Yii::$app->mailer->compose()   ->setFrom('******@163.com')   ->setTo('****@qq.com')   ->setSubject('This is a test mail ' )   ->setTextBody('内容')  ->send();  }

}

?>

使用clipboard.js实现页面内容复制到剪贴板

clipboard.js是一个github上的开源项目,可以实现纯 JavaScript (无 Flash)的浏览器内容复制到系统剪贴板的功能。

1、访问clipboard.js项目主页——https://github.com/zenorocha/clipboard.js

2、下载clipboard.min.js,并在页面中引用

  1. <!– clipboard Script –>
  2.         <script type=“text/javascript” src=“script/clipboard.min.js”></script>

 

3、在script中写实例化语句:

  1. <script type=“text/javascript”>
  2.         $(document).ready(function(){
  3.             var clipboard = new Clipboard(‘.btn’);
  4. }
  5. </script>

4、写页面按钮,实现点击按钮复制指定内容

  1. <button class=“btn” data-clipboard-text=“http://www.hbcloudwide.com/oss/video/7”>点击复制</button>

当然,clipboard.js还可以实现多种复制或剪切效果。具体用法参看github项目主页即可。

 

http://blog.csdn.net/softwave/article/details/50054477

windows下用composert方式安装YII2常见问题及解决

按照官网的安装程序,可能出现的错误及常见解决办法
1.首先安装composer报错
1)下载composer.exe慢,提供下载地址:
链接:http://pan.baidu.com/s/1c2Dgsgw 密码:nwak
2)首先需要打开php.ini中的

extension=php_openssl.dll

3)需要需要加载apache下的

LoadModule ssl_module modules/mod_ssl.so

然后重启apache,再重新安装composer

2.按官方文档使用Composer安装Yii时,执行命令:

composer global require "fxp/composer-asset-plugin:~1.0.0"

会出现以下错误

C:\Users\JMJ>composer global require "fxp/composer-asset-plugin:~1.0.0"
Changed current directory to C:/Users/JMJ/AppData/Roaming/Composer
./composer.json has been created
Loading composer repositories with package information
Updating dependencies (including require-dev)
  - Installing fxp/composer-asset-plugin (v1.0.3)
    Downloading: 100%

Deprecation Notice: The Composer\Package\LinkConstraint\MultiConstraint class is deprecated, use Composer\Semver\Constraint\MultiConstraint instead. in phar://C:/ProgramData/ComposerSetup/bin/composer.phar/src/Composer/Package/LinkConstraint/MultiConstraint.php:17
Deprecation Notice: The Composer\Package\LinkConstraint\LinkConstraintInterface interface is deprecated, use Composer\Semver\Constraint\ConstraintInterface instead. in phar://C:/ProgramData/ComposerSetup/bin/composer.phar/src/Composer/Package/LinkConstraint/LinkConstraintInterface.php:17
Plugin installation failed, rolling back
  - Removing fxp/composer-asset-plugin (v1.0.3)

Installation failed, deleting ./composer.json.


  [ReflectionException]
  Class Fxp\Composer\AssetPlugin\Repository\NpmRepository does not exist



  [ErrorException]
  Declaration of Fxp\Composer\AssetPlugin\Repository\AbstractAssetsRepository::whatProvides() should be compatible wi
  th Composer\Repository\ComposerRepository::whatProvides(Composer\DependencyResolver\Pool $pool, $name, $bypassFilte
  rs = false)


require [--dev] [--prefer-source] [--prefer-dist] [--no-progress] [--no-update] [--update-no-dev] [--update-with-dependencies] [--ignore-platform-reqs] [--sort-packages] [-o|--optimize-autoloader] [-a|--classmap-authoritative] [--] [<packages>]...

解决办法:
更新到最新版本即可:

composer global require "fxp/composer-asset-plugin:~1.1"

当时出错时,解决插件问题,参考原文地址:http://blog.weixiaodeyu.com/class-npmrepository-does-not-exist.html

3.发现生成的目录,没有vendor
解决办法:先进入网站目录,然后composer update
更新的时间有点长
在windows中用cmd进入目录的方法,请自行搜索

4.用composer upate时会出现Hub OAuth token to go over the API rate limit,需要Github账号,登录后,在下面的链接中
获取一个token,并输入

https://github.com/settings/tokens/new

5.测试yii是否安装成功
出现如下错误

yii\web\Request::cookieValidationKey must be configured with a secret key.

解决办法:
找到config/文件夹下的web.config文件,找到cookieValidationKey,并随便赋予一个值

这时候看到
Congratulations!
You have successfully created your Yii-powered application.

表示yii2安装成功了

解决使用 Composer 安装YII2的时候提示输入 Token hidden

如果你没有添加 GitHub 密钥的话,composer update 会提示你登录:

Could not fetch https://api.github.com/repos/RobinHerbots/jquery.inputmask/contents/bower.json?ref=03e65a2d28159e885e18acee9cae53ac6318372b, please create a GitHub OAuth token to go over the API rate limit
Head to https://github.com/settings/tokens/new?scopes=repo&description=Composer+on+localhost.localdomain+2015-05-19+1651
to retrieve a token. It will be stored in "/home/vagrant/.composer/auth.json" for future use by Composer.
Token (hidden): 

解决办法就是:

进入 https://github.com/settings/tokens 点击 「Generate new token」 新建一个 Token,选择默认新建就行,然后就会得到一个 Token,然后输入这个值就 OK 了。

使用TortoiseGit处理代码冲突

场景一
user0 有新提交
user1 没有pull -> 写新代码 -> pull -> 提示有冲突
解决办法一
-> stash save(把自己的代码隐藏存起来) -> 重新pull -> stash pop(把存起来的隐藏的代码取回来 ) -> 代码文件会显示冲突 -> 右键选择edit conficts,解决后点击编辑页面的 mark as resolved ->  commit&push
解决办法二(尽量少使用,这种方法的优点是在在原编辑器里处理冲突,代码逻辑看得更清楚一些)
-> stash save(把自己的代码隐藏存起来) -> 重新pull -> stash pop(把存起来的隐藏的代码取回来 ) -> 代码文件会显示冲突 -> 右键选择resolve conflict -> 打开文件解决冲突 -> commit&push
场景二
user0 有新提交
user1 没有pull -> 写新代码 -> commit&push -> 提示有冲突
解决办法一
-> pull -> 代码文件会显示冲突 -> 右键选择edit conficts,解决后点击编辑页面的 mark as resolved ->  commit&push

mysql 格式化时间日期 DATE_FORMAT,FROM_UNIXTIME,UNIX_TIME等

[mysql]

SELECT phone,FROM_UNIXTIME(ctime,’%Y-%c-%d %H:%i:%s’) 时间 from wx_yuyue WHERE ctime>1493568000 ORDER BY  ctime desc

[/mysql]

 

知识关键词:DATE_FORMAT

  1. select DATE_FORMAT(create_time,‘%Y%u’) weeks,count(caseid) count from tc_case group by weeks;
  2. select DATE_FORMAT(create_time,‘%Y%m%d’) days,count(caseid) count from tc_case group by days;
  3. select DATE_FORMAT(create_time,‘%Y%m’) months,count(caseid) count from tc_case group by months;

DATE_FORMAT(date,format)

根据format字符串格式化date值。下列修饰符可以被用在format字符串中:

%M 月名字(January……December)
%W 星期名字(Sunday……Saturday)
%D 有英语前缀的月份的日期(1st, 2nd, 3rd, 等等。)
%Y 年, 数字, 4 位
%y 年, 数字, 2 位
%a 缩写的星期名字(Sun……Sat)
%d 月份中的天数, 数字(00……31)
%e 月份中的天数, 数字(0……31)
%m 月, 数字(01……12)
%c 月, 数字(1……12)
%b 缩写的月份名字(Jan……Dec)
%j 一年中的天数(001……366)
%H 小时(00……23)
%k 小时(0……23)
%h 小时(01……12)
%I 小时(01……12)
%l 小时(1……12)
%i 分钟, 数字(00……59)
%r 时间,12 小时(hh:mm:ss [AP]M)
%T 时间,24 小时(hh:mm:ss)
%S 秒(00……59)
%s 秒(00……59)
%p AM或PM
%w 一个星期中的天数(0=Sunday ……6=Saturday )
%U 星期(0……52), 这里星期天是星期的第一天
%u 星期(0……52), 这里星期一是星期的第一天
%% 一个文字“%”。

 

对比DATE_FORMAT,FROM_UNIXTIME,UNIX_TIME

1. DATE_FORMAT() 函数用于以不同的格式显示日期/时间数据。

Sql代码  收藏代码
  1. DATE_FORMAT(date,format)

 

可以使用的格式有:

格式 描述

%a 缩写星期名
%b 缩写月名
%c 月,数值
%D 带有英文前缀的月中的天
%d 月的天,数值(00-31)
%e 月的天,数值(0-31)
%f 微秒
%H 小时 (00-23)
%h 小时 (01-12)
%I 小时 (01-12)
%i 分钟,数值(00-59)
%j 年的天 (001-366)
%k 小时 (0-23)
%l 小时 (1-12)
%M 月名
%m 月,数值(00-12)
%p AM 或 PM
%r 时间,12-小时(hh:mm:ss AM 或 PM)
%S 秒(00-59)
%s 秒(00-59)
%T 时间, 24-小时 (hh:mm:ss)
%U 周 (00-53) 星期日是一周的第一天
%u 周 (00-53) 星期一是一周的第一天
%V 周 (01-53) 星期日是一周的第一天,与 %X 使用
%v 周 (01-53) 星期一是一周的第一天,与 %x 使用
%W 星期名
%w 周的天 (0=星期日, 6=星期六)
%X 年,其中的星期日是周的第一天,4 位,与 %V 使用
%x 年,其中的星期一是周的第一天,4 位,与 %v 使用
%Y 年,4 位
%y 年,2 位

 

实例

下面的脚本使用 DATE_FORMAT() 函数来显示不同的格式。我们使用 NOW() 来获得当前的日期/时间:

Sql代码  收藏代码
  1. DATE_FORMAT(NOW(),‘%b %d %Y %h:%i %p’)
  2. DATE_FORMAT(NOW(),‘%m-%d-%Y’)
  3. DATE_FORMAT(NOW(),‘%d %b %y’)
  4. DATE_FORMAT(NOW(),‘%d %b %Y %T:%f’)

 

结果类似:

  1. Dec 29 2008 11:45 PM
  2. 12-29-2008
  3. 29 Dec 08
  4. 29 Dec 2008 16:25:46

 

如果要格式表中的数据,可以用:

 

2. MySQL 数据库中日期与时间函数 FROM_UNIXTIME(), UNIX_TIME() …

 

实例: date => int(11)

  1. SELECT FROM_UNIXTIME(date‘%Y-%c-%d %h:%i:%s’ ) as post_date ,
  2. date_format(NOW(), ‘%Y-%c-%d %h:%i:%s’ ) as post_date_gmt
  3. FROM `article`  where outkey = ‘Y’

 

1、FROM_UNIXTIME( unix_timestamp )
参数:通常是壹个十位的数字,如:1344887103
返回值:有两种,可能是类似 ‘YYYY-MM-DD HH:MM:SS’ 这样的字符串,也有可能是类似于 YYYYMMDDHHMMSS.uuuuuu 这样的数字,具体返回什么取决于该函数被调用的形式。

  1. mysql> select FROM_UNIXTIME(1344887103);
  2. +—————————+
  3. | FROM_UNIXTIME(1344887103) |
  4. +—————————+
  5. | 2012-08-14 03:45:03       |
  6. +—————————+
  7. 1 row in set (0.00 sec)

 

2、FROM_UNIXTIME( unix_timestamp ,format )
参数 unix_timestamp :与方法 FROM_UNIXTIME( unix_timestamp ) 中的参数含义一样;
参数 format : 转换之后的时间字符串显示的格式;
返回值:按照指定的时间格式显示的字符串;

  1. mysql> select FROM_UNIXTIME(1344887103,‘%Y-%M-%D %h:%i:%s’);
  2. +———————————————–+
  3. | FROM_UNIXTIME(1344887103,‘%Y-%M-%D %h:%i:%s’) |
  4. +———————————————–+
  5. | 2012-August-14th 03:45:03                     |
  6. +———————————————–+
  7. 1 row in set (0.00 sec)
  8. mysql> select FROM_UNIXTIME(1344887103,‘%Y-%m-%D %h:%i:%s’);
  9. +———————————————–+
  10. | FROM_UNIXTIME(1344887103,‘%Y-%m-%D %h:%i:%s’) |
  11. +———————————————–+
  12. | 2012-08-14th 03:45:03                         |
  13. +———————————————–+
  14. 1 row in set (0.00 sec)

 

 

 

1、UNIX_TIMESTAMP()

返回值:当前时间的UNIX格式数字串,或者说是 UNIX 时间戳(从 UTC 时间’1970-01-01 00:00:00’开始的秒数),通常为十位,如 1344887103。

Sql代码  收藏代码
  1. mysql> select unix_timestamp();
  2. +——————+
  3. | unix_timestamp() |
  4. +——————+
  5. |       1344887103 |
  6. +——————+
  7. 1 row in set (0.00 sec)

 

2、UNIX_TIMESTAMP( date )
参数:date 可能是个 DATE 字符串,DATETIME 字符串,TIMESTAPE 字符串,或者是一个类似于 YYMMDD 或者 YYYYMMDD 的数字串。
返回:从 UTC 时间’1970-01-01 00:00:00’开始到该参数之间的秒数。服务器将参数 date 解释成当前时区的壹个值并且将其转化成 UTC 格式的内部时间。客户端则可以自行设置当前时区。当 UNIX_TIMESTAMP() 用于壹个 TIMESTAMP 列时,函数直接返回内部时间戳的值;如果你传递壹个超出范围的时间到 UNIX_TIMESTAMP(),它的返回值是零。

  1. mysql> SELECT UNIX_TIMESTAMP();
  2. +——————+
  3. | UNIX_TIMESTAMP() |
  4. +——————+
  5. |       1344888895 |
  6. +——————+
  7. 1 row in set (0.00 sec)
  8. mysql> SELECT UNIX_TIMESTAMP(‘2012-08-14 16:19:23’);
  9. +—————————————+
  10. | UNIX_TIMESTAMP(‘2012-08-14 16:19:23’) |
  11. +—————————————+
  12. |                            1344932363 |
  13. +—————————————+
  14. 1 row in set (0.00 sec)

 

注意:如果你使用 UNIX_TIMESTAMP() 和 FROM_UNIXTIME() 来转换 TIMESTAMP 值与 Unix 时间戳的值,精度会丢失,因为这个映射在两个方向上不是一一对应的。比如说,由于本地时区的更改,有可能两个 UNIX_TIMESTAMP() 会映射到同壹个 Unix 时间戳的值。 FROM_UNIXTIME() 只会映射到原来的那个时间戳的值上。这里有个例子,在 CET 时区使用 TIMESTAMP:

  1. mysql> SELECT UNIX_TIMESTAMP(‘2005-03-27 03:00:00’);
  2. +—————————————+
  3. | UNIX_TIMESTAMP(‘2005-03-27 03:00:00’) |
  4. +—————————————+
  5. |                            1111885200 |
  6. +—————————————+
  7. mysql> SELECT UNIX_TIMESTAMP(‘2005-03-27 02:00:00’);
  8. +—————————————+
  9. | UNIX_TIMESTAMP(‘2005-03-27 02:00:00’) |
  10. +—————————————+
  11. |                            1111885200 |
  12. +—————————————+
  13. mysql> SELECT FROM_UNIXTIME(1111885200);
  14. +—————————+
  15. | FROM_UNIXTIME(1111885200) |
  16. +—————————+
  17. | 2005-03-27 03:00:00       |
  18. +—————————+