首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【腾讯云的1001种玩法】激发云力量--打造我的云端工具集

【腾讯云的1001种玩法】激发云力量--打造我的云端工具集

原创
作者头像
east
修改2017-06-19 19:27:05
2.9K0
修改2017-06-19 19:27:05
举报
文章被收录于专栏:east的专栏east的专栏

0.前言

日常工作中,有很多小需求,作为码农,总喜欢自己动手做点小东西出来,也成为学习与实践的好机会。 在使用腾讯云过程中,从环境搭建、各个小需求的构思,前后端技术的琢磨、学习、使用,收获很大。 现在整理出来和大家分享。

先说说做了哪些事情(都来源于实际小需求):

其他用途

1.环境搭建(php)

使用了腾讯云¥65/月 的 ubuntu 14 x64,经济实惠,适合投入有限的程序猿猿。

腾讯云
腾讯云

我的云端工具集都是基于后端php、前端h5实现。php可以和apache或nginx配套使用。

配置好的同学可以跳过 网络上资料很多,也可以根据自己的系统、喜欢的方式来配置、搭建环境 例如CentOS参考这里:http://blog.sina.com.cn/s/blog_505bf9af010137gf.html

apache2+php+mysql安装非常简单:

sudo apt-get update
sudo apt-get install apache2 php5
service apache2 start

然而更喜欢 nginx + php 的组合:

# 安装最新的nginx,模块、功能全。参考:http://nginx.org/en/linux_packages.html#stable
#  加入nginx官方key
wget http://nginx.org/keys/nginx_signing.key
sudo apt-key add nginx_signing.key
rm nginx_signing.key
#  加入nginx官方源
codename=$(lsb_release -a|grep Codename|awk '{print $2}')
echo deb http://nginx.org/packages/ubuntu/ $codename nginx > nginx.list
echo deb-src http://nginx.org/packages/ubuntu/ $codename nginx >> nginx.list
sudo cp nginx.list /etc/apt/sources.list.d/nginx.list
#  开始安装,默认已经开启,没开就service nginx start开启下
sudo apt-get update
sudo apt-get install nginx
#  看看安装好了没,默认80已经开啦
netstat -tln
#  如果无法访问,可以看看安全组有没有加上80: https://console.qcloud.com/cvm/securitygroup


# 安装php和常用库。也是默认就已经开启啦,没有就运行service php5-fpm开启
sudo apt-get install php5-common php5-fpm php5-cli php5-curl php5-gd php5-sqlite php5-mcrypt

# nginx使用用户“nginx”运行,php5-fpm使用“www-data”运行
# nginx无权限访问php5-fpm的sock来通信的
# 所以加个组,就有权限啦
sudo usermod -a -G www-data -G nginx  nginx

修改sudo vim /etc/nginx/conf.d/default.conf (假定代码放到/home/ubuntu/www目录)

server {
    listen       80;
    server_name  localhost;
    root /home/ubuntu/www;
    index   index.php index.html index.htm;
    error_page   500 502 503 504  /50x.html;
    location = /50x.html {
        root /home/ubuntu/www;
    }
    location ~ \.php$ {
         try_files      $uri = 404;
         fastcgi_split_path_info ^(.+\.php)(/.+)$;
         fastcgi_pass   unix:/var/run/php5-fpm.sock;
         fastcgi_index  index.php;
         include        fastcgi_params;
         fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;
    }
}

可选:允许 <?php 简化为 <?

sed -i 's/short_open_tag = Off/short_open_tag = On/g' /etc/php5/fpm/php.ini

重新启动nginx、php5-fpm

sudo service php5-fpm restart
sudo service nginx restart

写个demo页面访问http://server ip/看看

echo "<? phpinfo(); ?>" > /home/ubuntu/www/index.php

2.问卷系统

背景

Google Docs的表单功能很棒,支持很多种类型:文本框、单选、多选、下拉框、网格,分页等,然而在墙内不可用。 在腾讯问卷出来前,试过很多其他问卷系统,搭建复杂;第三方的问卷系统也不是那么好用,于是早先自己写了套,也是一个学习的过程。 (老早写的代码,风格、组织不太好,就不开源了^_^,有需要的可以拿去看看)

在很长一段时间里,大家中午一起订外卖。一直用这个东西来收集大家菜单,轮流担任外卖PM,负责下单、拿外卖。

前端:从Google表单分离了前端js代码,略作调整 后台:php来收集表单元素的json,存储;组装问卷页面;问卷回答的存储和下载

实现思路

  • step1:前端使用js,添加各类表单元素元素,记录对应数据。其中EntryType表示是文本、单选、网格等类型,Choices字段记录对应选项。
    {
      "EntryId": 3,
      "Composite": false,
      "QuestionTitle": "无标题的问题",
      "HelpText": "",
      "EntryType": 4,
      "Choices": [
        {
          "SelectedByDefault": false,
          "Value": "选项 1",
          "Label": "",
          "GoToPage": -2
        },
        {
          "SelectedByDefault": false,
          "Value": "选项 2",
          "Label": "",
          "GoToPage": -2
        }
      ],
      "OtherOptionEnabled": false,
      "Required": false,
      "GoToPageEnabled": false,
      "Position": 3
    }
  • step2:点“保存”按钮,以json格式,post整个表单数据,后台php存储下来,使用随机id标识。(目前以文件方式,没有使用db)。
  • step3:打开问卷时,使用id读取到对应问卷的json配置,根据EntryType生成html代码,返回给前端
  • step4:问卷回答后,以k=v&x=y提交,后台按题目顺序,将答案整理为csv,存储到文件
  • step5:为问卷生成了特殊的链接,可以查看、下载数据,把csv发给前端即可。

看看效果

创建表单

创建表单
创建表单

填写表单

填写表单
填写表单

可以改进的地方

当时是一只菜鸟,很多代码偏于实现,现在看来

  • 代码结构很乱,可以优化。
  • 表单元素的渲染采用了纯html的拼接,如果在后端使用tinybutstrong/前端使用art-template或angular.js/react/vue.js这类MVVM框架,可以更优雅的完成。

3.二维码工具

背景

经常有需要生成二维码,但:

  • 第三方二维码生成页面都会有很多其他元素,不喜欢
  • 不能保证第三方会不会收集、存储你输入的文本信息,例如网址、电话号码、wifi密码
  • 就想做一个自己玩

生成二维码

html5中,调用这个js即可

http://jeromeetienne.github.io/jquery-qrcode/

<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.5.2/jquery.min.js"></script>
<script type="text/javascript" src="http://jeromeetienne.github.io/jquery-qrcode/src/jquery.qrcode.js"></script>
<div id="qrcode"></div>
$('#qrcode').qrcode({
  width: 64,
  height: 64,
  text: 'hello, world'
});

但是jquery-qrcode生成的二维码在table或canvas中,无法右击保存 所以改造下,渲染成能右击-另存为的< img >标签

<img id="qr_img"/>
function make_qrcode(text, width) {
  width = width || 256;
  var div = $('<div></div>');//生成到这个虚拟的dom
  div.qrcode({
    width: width,
    height: width,
    text: text
  });
  // 获取实际DataUrl,给真实的img元素
  // 这个img就可以右击-另存为啦
  var url = div.find('canvas')[0].toDataURL();
  $('#qr_img').attr('src', url);
}

make_qrcode(256, 'hello, world')

突然来的一个需求

不是产品经理提的,自己挖掘的 玩手机游戏,家族里,大家想加个微信群:

  • 族长告诉大家自己的微信号,然后大家加
  • 族长把群二维码发给加她的人

好麻烦,如果能聊天中发二维码多简单。。。

  • 微信群中,群二维码,保存到手机
  • 上传这个二维码,假如结果为xxx
  • 生成一个短网址t.cn/abcd,发到游戏聊天会话中
  • 家族的小伙伴们 复制或手动打开,跳到一个页面,这个页面出现一个二维码,用微信扫描后加群

以后,族长只要上传群二维码,然后生成短网址,把网址发给大家,小伙伴们就可以愉快的加群啦

实现

二维码解析用这个js库

// 从input[type=file]或drop获得的file中解析二维码
var reader = new FileReader();
reader.onload = function(e) {
  qrcode.decode(e.target.result);
};
reader.readAsDataURL(file);

// navigator.getUserMedia开启摄像头扫描二维码
// 代码60多行,可以直接看http://t.ydjiao.com/qr/index.js,核心部分start_scan
// 定时采集video到canvas,然后调用qrcode.decode尝试解析canvas

以上二维码生成、解析都是纯js、前端完成 短网址只能依赖后台做转换了,写个php调用api.t.sina.com.cn的api就好

效果

二维码生成、解析、扫描
二维码生成、解析、扫描

4.地图搜索

背景

  • 知道公司班车几条线路所有停靠站点,先看看家附近哪里可以乘坐
  • 最好能在地图直观看到 家、所有站点位置

思路

  • 调用百度地图api,把所有地址转换成经纬度,在地图上标记出来

实现

这个比较简单,做下用户输入的查询的解析,发请求给百度地图api 但是确实做了些交互体验的东西,输入立刻查询、已查询地点缓存等

var city = '深圳';
var geocoder = new BMap.Geocoder();
var geolocation = new BMap.Geolocation();
var map = new BMap.Map('container');

geocoder.getPoint(city, function(point) {
  console.info('point:', point);
  map.centerAndZoom(point, 11);
  map.addControl(new BMap.MapTypeControl());
  map.addControl(new BMap.NavigationControl());
  map.addControl(new BMap.ScaleControl({anchor: BMAP_ANCHOR_TOP_LEFT}));
  ...
  // 更多代码可以直接打开http://t.ydjiao.com/map,右击,查看网页源代码
});
按中心搜索周边多个位置
按中心搜索周边多个位置

5.XCode dmg / docset下载地址获取

背景

  • 从Mac上的App Store下载XCode太慢,而且无法和同事分享安装包
  • 相关文档docset只能从XCode里面下载,太慢,也不方便分享
  • 第三方下载安全风险大 XCodeGhost安全事件

思路

  • 抓取XCode更新过程中,从Apple获取的下载地址,用工具下载

实现

跑起XCode,抓包看看,发现访问了https://developer.apple.com/library/downloads/docset-index.dvtdownloadableindex 打开看看,大礼包都在

这个文件是apple加的CFProperty,找了个php版本的解析工具CFPropertyList

$url = 'https://developer.apple.com/library/downloads/docset-index.dvtdownloadableindex';
$xml = file_get_contents($url);
$plist = new CFPropertyList\CFPropertyList();
$plist->parse($xml);
$docs = $plist->toArray();
// 然后按友好的格式输出就行啦

效果

XCode下载地址获取
XCode下载地址获取

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 0.前言
  • 1.环境搭建(php)
  • 2.问卷系统
    • 背景
      • 实现思路
        • 看看效果
          • 可以改进的地方
          • 3.二维码工具
            • 背景
              • 生成二维码
                • 突然来的一个需求
                  • 实现
                    • 效果
                    • 4.地图搜索
                      • 背景
                        • 思路
                          • 实现
                          • 5.XCode dmg / docset下载地址获取
                            • 背景
                              • 思路
                                • 实现
                                  • 效果
                                  相关产品与服务
                                  腾讯问卷
                                  腾讯问卷是专业的在线问卷调查平台,支撑了腾讯核心业务的⽤户、市场、产品研究工作。平台提供基于数据收集的专业调查研究解决方案,覆盖问卷调查、信息上报、在线测评、在线考试、360度评估、投票打卡等工作场景,致力于为客户提供高效的洞察决策工具。同时平台还拥有超百万级的真实样本用户,可以提供高效、精准的问卷有偿投放服务。
                                  领券
                                  问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档