里面,对应有图书名、出版社、评分(可选)、参评人数、一句话介绍等数据,目的就是把以上数据筛选出来存入MySQL中。
2.开始
先用命令创建一个MySQL数据库,一定要设置默认字符集为utf8 ,否则可能会导致无法插入中文数据:
MacBook-Pro:~ Tan$ mysql -u root -p
Enter password:
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 4
Server version: 5.7.19 MySQL Community Server (GPL)
Copyright (c) 2000, 2017, Oracle and/or its affiliates. All rights reserved.
Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
mysql> CREATE DATABASE NEWDATABASE DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;
Query OK, 1 row affected (0.00 sec)
douban.py用于网络请求和数据解析
#!/usr/bin/env python
# -*- coding: utf-8 -*-
import requests
from bs4 import BeautifulSoup
import sys
import time
from dbManager import DBManager
reload(sys)
sys.setdefaultencoding( "utf-8" )
# 获取图书TOP250
class Douban():
"""docstring for Douban"""
def __init__(self):
self.baseurl = 'https://book.douban.com/top250?start='
self.agent = 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/60.0.3112.113 Safari/537.36'
self.headers = {'User-Agent':self.agent}
self.page = 0
self.maxPage = 250 - 25
self.db = DBManager()
#拼接当前url
def getCurrentUrl(self):
url = self.baseurl + str(self.page)
print 'url:%s' % url
return url
#TOP250数据都在里面
def has_valign_but_no_width(self,tag):
return tag.has_attr('valign') and not tag.has_attr('width')
#获取每一页的数据
def loadPage(self):
url = self.getCurrentUrl()
result = requests.get(url,headers=self.headers).content
soup = BeautifulSoup(result,'html.parser', from_encoding='utf-8')
content = soup.find_all(self.has_valign_but_no_width)
#遍历,解析有用的数据
for item in content:
title = item.a['title']
publishingHouse = item.p.string
price = publishingHouse.split('/')[-1]
ratingNums = item.find('span',class_ = 'rating_nums').string
ratingPeoples = item.find('span',class_ = 'pl').string[1:-1].strip()
inq = ''
if item.find('span',class_ = 'inq'):
inq = item.find('span',class_ = 'inq').string
print 'title:%s\npublishingHouse:%s\nprice:%s\nratingNums:%s\nratingPeoples:%s\ninq:%s\n' % (title,publishingHouse,price,ratingNums,ratingPeoples,inq)
#插入数据库
self.db.insert(title,publishingHouse,price,ratingNums,ratingPeoples,inq)
#抓取完一页 休息3s
time.sleep(3)
#抓取下一页
self.page += 25
if self.page <= self.maxPage:
self.loadPage()
else:
# 爬完就关闭数据库
self.db.closeDB()
if __name__ == '__main__':
douban = Douban()
douban.loadPage()
dbManager用于数据存储
#!/usr/bin/env python
# -*- coding: utf-8 -*-
import MySQLdb
import sys
reload(sys)
sys.setdefaultencoding( "utf-8" )
class DBManager():
"""docstring for DBManager"""
SQL_CREATE = '''CREATE TABLE IF NOT EXISTS DOUBANBOOK (id int unsigned not null AUTO_INCREMENT primary key,
title varchar(20) not null,
publishingHouse varchar(50),
price varchar(10),
ratingNums varchar(10),
ratingPeoples varchar(20),
inq varchar(20))'''
SQL_INSERT = '''INSERT INTO DOUBANBOOK (title,publishingHouse,price,ratingNums,ratingPeoples,inq) VALUES (%s,%s,%s,%s,%s,%s)'''
def __init__(self):
self.host = 'localhost'
self.dbName = '数据库名'
self.userName = 'root'
self.password = '密码'
self._db = MySQLdb.connect(host = self.host,
user = self.userName,
passwd = self.password,
db = self.dbName,
charset="utf8")
self._cursor = self._db.cursor()
self._execute(sql=self.SQL_CREATE)
def _execute(self,params=None,sql=''):
if params:
self._cursor.execute(sql,params)
else:
self._cursor.execute(sql)
def insert(self,title,publishingHouse,price,ratingNums,ratingPeoples,inq):
try:
self._execute(params=(title,publishingHouse,price,ratingNums,ratingPeoples,inq),sql=self.SQL_INSERT)
self._db.commit()
except Exception as e:
print 'db error %s' % e
self._db.rollback()
def closeDB(self):
self._db.close()
3.最后
运行douban.py:
url:https://book.douban.com/top250?start=0
title:追风筝的人
publishingHouse:[美] 卡勒德·胡赛尼 / 李继宏 / 上海人民出版社 / 2006-5 / 29.00元
price: 29.00元
ratingNums:8.9
ratingPeoples:283124人评价
inq:为你,千千万万遍
title:小王子
publishingHouse:[法] 圣埃克苏佩里 / 马振聘 / 人民文学出版社 / 2003-8 / 22.00元
price: 22.00元
ratingNums:9.0
ratingPeoples:225146人评价
inq:献给长成了大人的孩子们
title:围城
publishingHouse:钱锺书 / 人民文学出版社 / 1991-2 / 19.00
price: 19.00
ratingNums:8.9
ratingPeoples:188666人评价
inq:对于“人艰不拆”四个字最彻底的违抗
title:解忧杂货店
publishingHouse:[日] 东野圭吾 / 李盈春 / 南海出版公司 / 2014-5 / 39.50元
price: 39.50元
ratingNums:8.6
ratingPeoples:233024人评价
inq:一碗精心熬制的东野牌鸡汤,拒绝很难
数据库结构:
+-----------------+------------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+-----------------+------------------+------+-----+---------+----------------+
| id | int(10) unsigned | NO | PRI | NULL | auto_increment |
| title | varchar(20) | NO | | NULL | |
| publishingHouse | varchar(50) | YES | | NULL | |
| price | varchar(10) | YES | | NULL | |
| ratingNums | varchar(10) | YES | | NULL | |
| ratingPeoples | varchar(20) | YES | | NULL | |
| inq | varchar(20) | YES | | NULL | |
+-----------------+------------------+------+-----+---------+----------------+
接下来,准备用这个数据库数据配合flask_restful做一个简单的api,返回给App使用。
你可能感兴趣的:(学习Python:requests + BeautifulSoup + MySQLdb抓取简单数据)
对于简单的HTML、CSS、JavaScript前端,我们可以通过几种方式连接后端
昨今
前端 html css
1.使用FetchAPI发送HTTP请求(最简单的方式)://home.html//示例:提交表单数据到后端constsubmitForm=async(formData)=>{try{constresponse=awaitfetch('http://your-backend-url/api/submit',{method:'POST',headers:{'Content-Type':'applic
网络安全常识
网络安全-老纪
web安全 安全
随着互联网和移动互联网的持续火热,人们的生活也越来越离不开网络,网络安全,在这个信息化时代显得尤为重要,那么网络攻击和安全,这一攻守之间,主要涵盖哪些要点呢,下面我们就来对此进行抽丝剥茧,逐条解析。XSS(跨站脚本攻击)最常见的是cookie劫持,简单来说就是我们用浏览器登录一个网站,主要是用存在客户端浏览器里的cookie来保存客户唯一标识的令牌,在Java写就的网站里,是一个jsessioni
《vue.js前端框架技术》
韩靓.
前端框架 vue.js flutter
一、引言在当今快速发展的互联网时代,前端开发技术不断推陈出新,众多框架和工具如雨后春笋般涌现,而Vue.js凭借其独特的优势,在前端开发领域中占据了重要的一席之地。它以简洁的语法、高效的性能和灵活的扩展性,为开发者提供了一种便捷且强大的方式来构建各类交互式的用户界面。无论是简单的企业展示网站、小型的移动应用,还是复杂的大型单页面应用(SPA),Vue.js都展现出了卓越的适应性和实用性,能够满足不
【合集】Java进阶——Java深入学习的笔记汇总 & 再论面向对象、数据结构和算法、JVM底层、多线程、类加载、
web_15534274656
面试 学习路线 阿里巴巴 java 学习 笔记
前言spring作为主流的JavaWeb开发的开源框架,是Java世界最为成功的框架,持续不断深入认识spring框架是Java程序员不变的追求;而spring的底层其实就是Java,因此,深入学习Spring和深入学习Java是硬币的正反面,两者相辅相成,相互促进。本篇博客是一篇不定期持续更新的博客,是一些Java深入学习的笔记汇总。目录前言面向对象专题再论面向对象封装和关键字private,t
全面了解HTTP(一)
qq_40055200
http
全面了解HTTP(二)-CSDN博客web及网络基础使用HTTP协议访问web:HTTP:网络基础TCP/IP与HTTP关系密切的协议:IP,TCP,DNS负责域名解析的DNS服务各种协议与HTTP协议的关系URI和URL简单的HTTP协议HTTP协议用于客户端和服务端之间的通信通过请求和响应的交换达成通信HTTP是不保存状态的协议请求URI的定位资源告知服务器意图的HTTP方法持久连接节省流量使
B4X编程语言:B4XTable常用属性和方法
蓝色天空上的云朵
# B4X控件 开发语言 B4X语言 笔记
一、B4XTable常用属性和方法1、AddColumn为B4XTable添加一个列对象,B4XTable通过添加列对象创建表格结构。语法:AddColumn(TitleAsString,ColumnTypeAsInt)AsB4XTableColumnTitle:列标题,默认情况下等于列的ID(ColumnID)ColumnType:列的数据类型,共四种类型,分别是:COLUMN_TYPE_TEX
还活在上个时代,Etcd 3.0 实现分布式锁竟如此简单
程序员荒生
开源学习 etcd 分布式
上下文传统Python单机系统部署中,由于GIL的存在,相同进程中我们可以不用处理并发问题。但是随着业务发展需要,原有单机系统演变成分布式或多进程系统后。这将使原有的单机单进程并发控制策略失效。为了解决该问题需要引入一种跨进程、跨机器的互斥锁机制来控制共享资源的访问,这也就是分布式锁的由来。所以,分布式锁的引入是为了保障多台机器或多个进程对共享资源读写的同步,保证数据的最终一致性。分布式锁天生具有
MyBatis的if标签的基本使用
君子剑mango
# MyBatis框架 mybatis java 开发语言
在MyBatis框架中,if标签用于在构建SQL语句时,根据参数条件判断的结果,动态地选择加入或不加where条件中。一常见使用在使用MyBatis处理查询逻辑的时候,常用的是判断一些参数是否为空,列举常用的几种情况展示1.1数据准备1.1.1创建表模型CREATETABLE`approval_info`(`id`BIGINTNOTNULLAUTO_INCREMENT,`info_name`VAR
Vue3 使用 ref、reactive响应式丢失
张帅涛_666
Vue3开发 vue.js javascript 前端
文章目录一、refreactive实例1.引用refreactive属性2.refreactive替换整条数据3.refreactive解构赋值一、refreactive实例1.引用refreactive属性单独引用refreactive修改其中某一个属性,状态变量不会丢失,正常使用import{ref,reactive,toRefs,toRef}from"vue";constcount=ref(
面试官:你知道怎么解决vue2响应式丢失吗?
zayyo
vue.js javascript 前端
vue2是如何追踪数据变化形成响应?概括版:通过遍历劫持对象的所有属性来实现响应式数据(Object.defineProperty)。专业版:1.初始化阶段:在Vue实例化过程中,Vue会遍历数据对象(通常是data属性中定义的数据)的所有属性,通过Object.defineProperty方法为每个属性添加getter和setter函数。这样做的目的是为了在属性被访问或修改时能够进行依赖收集和派
golang - context包使用示例 以及 底层实现
切尔诺贝尔
golang go 上下文 context 并发
文章目录1.context常用方法,以及各种适用于什么场景1.1context含有的方法1.2方法适用场景和伪代码示例1.2.1值传递:比如gin框架中用来传递key,value的值,自己简单示例如下1.2.2超时控制-timeout:http请求设置超时时间1.2.3,超时控制-deadline:比如文件io或者网络io等耗时操作,可以查看剩余的时间是否充足,决定是否进行下一步操作1.2.4.取
23行为型设计模式——迭代器模式
凢曐
设计模式 迭代器模式 c++
一、迭代器模式介绍迭代器模式(IteratorPattern)是一种行为型设计模式,旨在提供一种方法来顺序访问集合对象中的元素,而无需暴露集合的内部表示。简单来说,它允许你遍历一个集合中的所有元素而无需直接访问集合内部的结构。例如STL中的容器存在输入输出迭代器,包括双向迭代器、随机访问迭代器等,算法通过迭代器就可以以某种权限去访问容器中的数据。GoF一书对迭代器模式的介绍迭代器(Iterator
Redis常用数据类型
pingcode
面试题 redis
Redis是Map类型的存储方式,所有数据都采用key:value形式存储,key是字符串,value有以下几种常用数据类型:①String:最基本的数据类型,可以是字符串、整数或浮点数。②List:按插入顺序排序的字符串列表。③Set:唯一字符串的无序集合。④Hash:包含键值对的无序散列。⑤ZSet:唯一字符串的有序集合,根据每个字符串的分数来维持顺序。
【etcd】ubuntu22安装,与redis对比的区别
{⌐■_■}
etcd redis chrome 服务器 数据库 golang 缓存
安装方法1:通过apt安装(简单,但版本可能较旧)步骤更新软件包列表:sudoaptupdate安装etcd:sudoaptinstalletcd启动etcd服务:sudosystemctlstartetcd验证安装:etcdctlversion如果输出类似以下内容,表示安装成功:etcdctlversion:3.4.20APIversion:3.4设置开机自启(可选):sudosystemctl
LINUX系统优化
敖光 SRE
linux 运维 服务器
LINUX系统优化企业生产场景中Linux系统的分区方案及内核企业生产场景中Linux系统的分区方案常规的分区方案如下:方案1:针对网站集群架构中的某个节点服务器分区,该服务器上的数据有多份(其他节点也有)且数据不太重要,建议的分区方案如下。/boot:设置为100~200MB。swap:物理内存的1.5倍,当内存大于或等于8GB时,配置为8~16GB即可。/:剩余硬盘空间大小(/usr、/hom
跨时钟域(clka,clkb)
dajunzhi
cdc
1.跨时钟会发生竞争和冒险竞争:逻辑电路中,不同路线汇聚到一个一点时有先后时序,称为逻辑竞争冒险:竞争产生的电平不稳定的现象称为冒险跨时钟域的主要问题是阻止竞争冒险的发生,杜绝亚稳态在电路当中的传播2.单比特数据解决竞争和冒险2.1cdc时将数据打两拍,第一拍输出的结果可能有亚稳态,但是到了第二拍处理之后输出结果会杜绝亚稳态的传播。但是这样但比特的数据可能会有丢失。慢时钟到快时钟:打两拍快时钟到慢
Etcd教程 — 第二章 Etcd集群静态发现_etcd 双节点集群
2401_87361150
etcd 数据库
监听用于和节点之间通信的url,可监听多个,集群内部将通过这些url进行数据交互(如选举,数据同步等)–initial-advertise-peer-urls建议用于和节点之间通信的url,节点间将以该值进行通信。–listen-client-urls监听的用于和客户端通信的url,同样可以监听多个。–advertise-client-urls建议使用的和客户端通信url,该值用于etcd代理或e
蓝桥杯篇---IAP15F2K61S2串口
Ronin-Lotus
上位机知识篇 嵌入式硬件篇 蓝桥杯 单片机 职场和发展 嵌入式硬件 c IAP15F2K61S2
文章目录前言简介串口通信的基本参数1.波特率2.数据位3.停止位4.校验位串口相关寄存器1.SCON2.SBUF3.PCON4.TMOD5.TH1/TL1串口使用步骤1.配置波特率2.配置串口模式3.使能串口中断4.发送数据5.接收数据6.处理中断示例代码:串口发送与接收示例代码:串口接收数据并回显注意事项1.波特率设置2.中断优先级3.数据缓冲区4.错误处理总结前言本文仅仅简单介绍了IAP15F
机器学习:k均值
golemon.
ML 机器学习 均值算法 人工智能
所有代码和文档均在golitter/Decoding-ML-Top10:使用Python优雅地实现机器学习十大经典算法。(github.com),欢迎查看。在“无监督学习”中,训练样本的标记信息是未知的,目标是通过对无标记训练样本的学习来揭示数据的内在性质及规律,为进一步的数据分析提供基础,较为经典的是聚类。**聚类试图将数据集中的样本划分为若干个通常是不相交的子集,每个子集称为一个“簇”。**聚
关于go-context包
敖光 SRE
go基础知识 golang 数据库 开发语言
思维导图目的为了在不同的goroutine之间或跨API边界传递超时、取消信号和其他请求范围内的值(与该请求相关的值。这些值可能包括用户身份信息、请求处理日志、跟踪信息等等)。常用场景数据操作网络请求RPC操作context接口context包在提供了一个用于跨API边界传递超时、取消信号和其他请求范围值的通用数据结构。用于在多个Goroutine和函数之间传递请求范围内的信息。核心方法:Dead
js实现按钮加减,长按按钮数字一直可变
iUserWang
javascript js javascript 购物按钮 加减按钮 长按按钮
今天工作过程中遇到一个小问题,即实现按钮加减,单击数据+/-1,长按时会按时间来每秒+/-1。实现后如图所示:按钮显示代码如下:—//减号按钮//数字显示+//加号按钮网上很多资料都只提供了单击事件,而对于长按按钮数字变化都无介绍,部分资料介绍为非js,以下对两种作出说明。一、仅单击事件按钮加减代码:varnum_jia=document.getElementById("num-jia");var
lua mysql 事务_Lua 数据库访问
weixin_39998906
lua mysql 事务
Lua数据库访问本文主要为大家介绍Lua数据库的操作库:LuaSQL。他是开源的,支持的数据库有:ODBC,ADO,Oracle,MySQL,SQLite和PostgreSQL。本文为大家介绍MySQL的数据库连接。LuaSQL可以使用LuaRocks来安装可以根据需要安装你需要的数据库驱动。LuaRocks安装方法:$wgethttp://luarocks.org/releases/luaroc
lua可以调用mysql数据库吗_Lua 数据库访问
女王丁丁
Lua数据库访问作者:杨梦鸽校对:翟舒青本文主要为大家介绍Lua数据库的操作库:LuaSQL。他是开源的,支持的数据库有:ODBC,ADO,Oracle,MySQL,SQLite和PostgreSQL。本文为大家介绍MySQL的数据库连接。LuaSQL可以使用LuaRocks来安装可以根据需要安装你需要的数据库驱动。LuaRocks安装方法:$wgethttp://luarocks.org/rel
使用 Qt 插件和 SQLCipher 实现 SQLite 数据库加密与解密
web_15534274656
面试 学习路线 阿里巴巴 数据库 qt sqlite
SQLite作为一种轻量级的数据库,被广泛应用于各种桌面和移动应用中。然而,SQLite本身并不支持数据加密,这时SQLCipher成为一个理想的解决方案。本文将详细介绍如何在Qt项目中集成SQLCipher,实现SQLite数据库的加密与解密,包括创建加密数据库、插入数据以及查询数据的完整流程。目录简介前置条件项目配置代码实现创建加密数据库并插入数据读取加密数据库并查询数据常见问题与解决总结简介
Linux下使用poll函数编写UDP客户端、服务器程序
崔杰城
linux udp 网络协议 网络
一、UDP服务器与客户端的区别对于UDP服务器与客户端,两者都可以通过sendto和recvfrom函数收发数据,它们的主要区别是:1.服务器一般是等待并响应来自客户端的请求,客户端则是主动发送请求并且等待服务器的响应。2.服务器端要将地址和端口号绑定,如果不绑定就无法使用recvfrom函数接受数据(也就是说服务器需要调用bind函数将一个套接字与一个地址绑定,而客户端不需要)。所以对于UDP,
TypeScript 与后端开发Node.js
m0_74825746
面试 学习路线 阿里巴巴 typescript node.js javascript
文章目录一、搭建TypeScript+Node.js项目(一)初始化项目并安装相关依赖1、创建项目目录并初始化2、安装必要的依赖包(二)配置TypeScript编译选项(如模块解析方式适合后端)二、编写服务器代码(一)定义路由类型(使用Express等框架)(二)处理请求和响应的类型(包括中间件的类型)1、请求类型处理2、响应类型处理3、中间件类型处理三、数据库交互(一)使用Type-Safe的数
mysql 删除数据的四种方法
m0_74824780
mysql android 数据库
在MySQL数据库中,删除数据是一个常见的操作,它允许从表中移除不再需要的数据,本文就来介绍一下四种方法,具有一定的参考价值,感兴趣的可以了解一下目录写在前面?方法介绍1.DELETE语句示例:??2.DROPTABLE语句:3.?TRUNCATETABLE示例:4.使用外键约束:示例:??方法优缺点1.DELETE语句:2.TRUNCATETABLE语句:3.DROPTABLE语句:4.使用外键
Node.js使用教程
m0_74824112
面试 学习路线 阿里巴巴 node.js vim 编辑器
Node.js使用教程Node.js是一个基于ChromeV8引擎的JavaScript运行环境,它让JavaScript运行在服务器端。以下是一个简单的Node.js使用教程:一、Node.js开发环境和编译1.1安装Node.js访问Node.js官网下载并安装适合您操作系统的Node.js版本。1.2创建一个Node.js项目在您的工作目录中,创建一个新的文件夹作为项目目录,例如命名为my_
【Spring:Caused by java.lang.ClassNotFoundException 】
m0_74823490
面试 学习路线 阿里巴巴 java spring tomcat
Spring:Causedby:java.lang.ClassNotFoundException:org.springframework.dao.support.DaoSupportSpring中使用Mybatis连接数据库时可能会出现以上错误,但是当出现以上错误时说明你在applicationContext.xml文件中所做的相关操作:spring整合myBATis后控制的创建连接用的对象加载M
HBase基本技巧:掌握高效数据管理的秘诀
狮歌~资深攻城狮
java android 数据库
HBase基本技巧:掌握高效数据管理的秘诀嘿,小伙伴们!现在你已经对HBase有了初步的了解,接下来让我们深入探讨一些HBase的基本技巧。这些技巧不仅能帮助你更高效地管理和操作数据,还能让你在面对复杂场景时游刃有余。1.行键设计的艺术什么是行键?行键(RowKey)是HBase表中每一行的唯一标识符。它的设计直接影响到查询性能和数据分布。因此,合理设计行键是非常重要的。设计原则•避免热点问题:如
redis学习笔记——不仅仅是存取数据
Everyday都不同
returnSource expire/del incr/lpush 数据库分区 redis
最近项目中用到比较多redis,感觉之前对它一直局限于get/set数据的层面。其实作为一个强大的NoSql数据库产品,如果好好利用它,会带来很多意想不到的效果。(因为我搞java,所以就从jedis的角度来补充一点东西吧。PS:不一定全,只是个人理解,不喜勿喷)
1、关于JedisPool.returnSource(Jedis jeids)
这个方法是从red
SQL性能优化-持续更新中。。。。。。
atongyeye
oracle sql
1 通过ROWID访问表--索引
你可以采用基于ROWID的访问方式情况,提高访问表的效率, , ROWID包含了表中记录的物理位置信息..ORACLE采用索引(INDEX)实现了数据和存放数据的物理位置(ROWID)之间的联系. 通常索引提供了快速访问ROWID的方法,因此那些基于索引列的查询就可以得到性能上的提高.
2 共享SQL语句--相同的sql放入缓存
3 选择最有效率的表
[JAVA语言]JAVA虚拟机对底层硬件的操控还不完善
comsci
JAVA虚拟机
如果我们用汇编语言编写一个直接读写CPU寄存器的代码段,然后利用这个代码段去控制被操作系统屏蔽的硬件资源,这对于JVM虚拟机显然是不合法的,对操作系统来讲,这样也是不合法的,但是如果是一个工程项目的确需要这样做,合同已经签了,我们又不能够这样做,怎么办呢? 那么一个精通汇编语言的那种X客,是否在这个时候就会发生某种至关重要的作用呢?
&n
lvs- real
男人50
LVS
#!/bin/bash
#
# Script to start LVS DR real server.
# description: LVS DR real server
#
#. /etc/rc.d/init.d/functions
VIP=10.10.6.252
host='/bin/hostname'
case "$1" in
sta
生成公钥和私钥
oloz
DSA 安全加密
package com.msserver.core.util;
import java.security.KeyPair;
import java.security.PrivateKey;
import java.security.PublicKey;
import java.security.SecureRandom;
public class SecurityUtil {
UIView 中加入的cocos2d,背景透明
374016526
cocos2d glClearColor
要点是首先pixelFormat:kEAGLColorFormatRGBA8,必须有alpha层才能透明。然后view设置为透明glView.opaque = NO;[director setOpenGLView:glView];[self.viewController.view setBackgroundColor:[UIColor clearColor]];[self.viewControll
mysql常用命令
香水浓
mysql
连接数据库
mysql -u troy -ptroy
备份表
mysqldump -u troy -ptroy mm_database mm_user_tbl > user.sql
恢复表(与恢复数据库命令相同)
mysql -u troy -ptroy mm_database < user.sql
备份数据库
mysqldump -u troy -ptroy
我的架构经验系列文章 - 后端架构 - 系统层面
agevs
JavaScript jquery css html5
系统层面:
高可用性
所谓高可用性也就是通过避免单独故障加上快速故障转移实现一旦某台物理服务器出现故障能实现故障快速恢复。一般来说,可以采用两种方式,如果可以做业务可以做负载均衡则通过负载均衡实现集群,然后针对每一台服务器进行监控,一旦发生故障则从集群中移除;如果业务只能有单点入口那么可以通过实现Standby机加上虚拟IP机制,实现Active机在出现故障之后虚拟IP转移到Standby的快速
利用ant进行远程tomcat部署
aijuans
tomcat
在javaEE项目中,需要将工程部署到远程服务器上,如果部署的频率比较高,手动部署的方式就比较麻烦,可以利用Ant工具实现快捷的部署。这篇博文详细介绍了ant配置的步骤(http://www.cnblogs.com/GloriousOnion/archive/2012/12/18/2822817.html),但是在tomcat7以上不适用,需要修改配置,具体如下:
1.配置tomcat的用户角色
获取复利总收入
baalwolf
获取
public static void main(String args[]){
int money=200;
int year=1;
double rate=0.1;
&
eclipse.ini解释
BigBird2012
eclipse
大多数java开发者使用的都是eclipse,今天感兴趣去eclipse官网搜了一下eclipse.ini的配置,供大家参考,我会把关键的部分给大家用中文解释一下。还是推荐有问题不会直接搜谷歌,看官方文档,这样我们会知道问题的真面目是什么,对问题也有一个全面清晰的认识。
Overview
1、Eclipse.ini的作用
Eclipse startup is controlled by th
AngularJS实现分页功能
bijian1013
JavaScript AngularJS 分页
对于大多数web应用来说显示项目列表是一种很常见的任务。通常情况下,我们的数据会比较多,无法很好地显示在单个页面中。在这种情况下,我们需要把数据以页的方式来展示,同时带有转到上一页和下一页的功能。既然在整个应用中这是一种很常见的需求,那么把这一功能抽象成一个通用的、可复用的分页(Paginator)服务是很有意义的。
&nbs
[Maven学习笔记三]Maven archetype
bit1129
ArcheType
archetype的英文意思是原型,Maven archetype表示创建Maven模块的模版,比如创建web项目,创建Spring项目等等.
mvn archetype提供了一种命令行交互式创建Maven项目或者模块的方式,
mvn archetype
1.在LearnMaven-ch03目录下,执行命令mvn archetype:gener
【Java命令三】jps
bit1129
Java命令
jps很简单,用于显示当前运行的Java进程,也可以连接到远程服务器去查看
[hadoop@hadoop bin]$ jps -help
usage: jps [-help]
jps [-q] [-mlvV] [<hostid>]
Definitions:
<hostid>: <hostname>[:
ZABBIX2.2 2.4 等各版本之间的兼容性
ronin47
zabbix更新很快,从2009年到现在已经更新多个版本,为了使用更多zabbix的新特性,随之而来的便是升级版本,zabbix版本兼容性是必须优先考虑的一点 客户端AGENT兼容
zabbix1.x到zabbix2.x的所有agent都兼容zabbix server2.4:如果你升级zabbix server,客户端是可以不做任何改变,除非你想使用agent的一些新特性。 Zabbix代理(p
unity 3d还是cocos2dx哪个适合游戏?
brotherlamp
unity自学 unity教程 unity视频 unity资料 unity
unity 3d还是cocos2dx哪个适合游戏?
问:unity 3d还是cocos2dx哪个适合游戏?
答:首先目前来看unity视频教程因为是3d引擎,目前对2d支持并不完善,unity 3d 目前做2d普遍两种思路,一种是正交相机,3d画面2d视角,另一种是通过一些插件,动态创建mesh来绘制图形单元目前用的较多的是2d toolkit,ex2d,smooth moves,sm2,
百度笔试题:一个已经排序好的很大的数组,现在给它划分成m段,每段长度不定,段长最长为k,然后段内打乱顺序,请设计一个算法对其进行重新排序
bylijinnan
java 算法 面试 百度 招聘
import java.util.Arrays;
/**
* 最早是在陈利人老师的微博看到这道题:
* #面试题#An array with n elements which is K most sorted,就是每个element的初始位置和它最终的排序后的位置的距离不超过常数K
* 设计一个排序算法。It should be faster than O(n*lgn)。
获取checkbox复选框的值
chiangfai
checkbox
<title>CheckBox</title>
<script type = "text/javascript">
doGetVal: function doGetVal()
{
//var fruitName = document.getElementById("apple").value;//根据
MySQLdb用户指南
chenchao051
mysqldb
原网页被墙,放这里备用。 MySQLdb User's Guide
Contents
Introduction
Installation
_mysql
MySQL C API translation
MySQL C API function mapping
Some _mysql examples
MySQLdb
HIVE 窗口及分析函数
daizj
hive 窗口函数 分析函数
窗口函数应用场景:
(1)用于分区排序
(2)动态Group By
(3)Top N
(4)累计计算
(5)层次查询
一、分析函数
用于等级、百分点、n分片等。
函数 说明
RANK() &nbs
PHP ZipArchive 实现压缩解压Zip文件
dcj3sjt126com
PHP zip
PHP ZipArchive 是PHP自带的扩展类,可以轻松实现ZIP文件的压缩和解压,使用前首先要确保PHP ZIP 扩展已经开启,具体开启方法就不说了,不同的平台开启PHP扩增的方法网上都有,如有疑问欢迎交流。这里整理一下常用的示例供参考。
一、解压缩zip文件 01 02 03 04 05 06 07 08 09 10 11
精彩英语贺词
dcj3sjt126com
英语
I'm always here
我会一直在这里支持你
&nb
基于Java注解的Spring的IoC功能
e200702084
java spring bean IOC Office
java模拟post请求
geeksun
java
一般API接收客户端(比如网页、APP或其他应用服务)的请求,但在测试时需要模拟来自外界的请求,经探索,使用HttpComponentshttpClient可模拟Post提交请求。 此处用HttpComponents的httpclient来完成使命。
import org.apache.http.HttpEntity ;
import org.apache.http.HttpRespon
Swift语法之 ---- ?和!区别
hongtoushizi
? swift !
转载自: http://blog.sina.com.cn/s/blog_71715bf80102ux3v.html
Swift语言使用var定义变量,但和别的语言不同,Swift里不会自动给变量赋初始值,也就是说变量不会有默认值,所以要求使用变量之前必须要对其初始化。如果在使用变量之前不进行初始化就会报错:
var stringValue : String
//
centos7安装jdk1.7
jisonami
jdk centos
安装JDK1.7
步骤1、解压tar包在当前目录
[root@localhost usr]#tar -xzvf jdk-7u75-linux-x64.tar.gz
步骤2:配置环境变量
在etc/profile文件下添加
export JAVA_HOME=/usr/java/jdk1.7.0_75
export CLASSPATH=/usr/java/jdk1.7.0_75/lib
数据源架构模式之数据映射器
home198979
PHP 架构 数据映射器 datamapper
前面分别介绍了数据源架构模式之表数据入口、数据源架构模式之行和数据入口数据源架构模式之活动记录,相较于这三种数据源架构模式,数据映射器显得更加“高大上”。
一、概念
数据映射器(Data Mapper):在保持对象和数据库(以及映射器本身)彼此独立的情况下,在二者之间移动数据的一个映射器层。概念永远都是抽象的,简单的说,数据映射器就是一个负责将数据映射到对象的类数据。
&nb
在Python中使用MYSQL
pda158
mysql python
缘由 近期在折腾一个小东西须要抓取网上的页面。然后进行解析。将结果放到
数据库中。 了解到
Python在这方面有优势,便选用之。 由于我有台
server上面安装有
mysql,自然使用之。在进行数据库的这个操作过程中遇到了不少问题,这里
记录一下,大家共勉。
python中mysql的调用
百度之后能够通过MySQLdb进行数据库操作。
单例模式
hxl1988_0311
java 单例 设计模式 单件
package com.sosop.designpattern.singleton;
/*
* 单件模式:保证一个类必须只有一个实例,并提供全局的访问点
*
* 所以单例模式必须有私有的构造器,没有私有构造器根本不用谈单件
*
* 必须考虑到并发情况下创建了多个实例对象
* */
/**
* 虽然有锁,但是只在第一次创建对象的时候加锁,并发时不会存在效率
27种迹象显示你应该辞掉程序员的工作
vipshichg
工作
1、你仍然在等待老板在2010年答应的要提拔你的暗示。 2、你的上级近10年没有开发过任何代码。 3、老板假装懂你说的这些技术,但实际上他完全不知道你在说什么。 4、你干完的项目6个月后才部署到现场服务器上。 5、时不时的,老板在检查你刚刚完成的工作时,要求按新想法重新开发。 6、而最终这个软件只有12个用户。 7、时间全浪费在办公室政治中,而不是用在开发好的软件上。 8、部署前5分钟才开始测试。