【selenium2】【selenium基础语法】
#栗子 设置浏览器窗口大小
driver.set_window_size(480,800) #栗子 设置浏览器大小为最大
maximize_window() 控制浏览器前进、后退
#栗子
from selenium import webdriver driver = webdriver.Chrome() #访问百度首页
first_url = 'http://www.baidu.com'
print('now access %s' % (first_url))
driver.get(first_url) #访问新闻首页
second_url = 'http://news.baidu.com'
print('now access %s ' % (second_url))
driver.get(second_url) #返回到百度首页
print('back to %s' % first_url)
driver.back() #前进到新闻也
print('forward to %s' % (second_url))
driver.forward() #栗子
from selenium import webdriver
from selenium.webdriver.common.by import By driver = webdriver.Chrome()
driver.get('http://www.baidu.com') #获得输入框的尺寸
size = driver.find_element(By.ID,'kw').size
print(size) #返回百度底部备案信息
text = driver.find_element(By.ID,'cp').text
print(text) #返回元素的属性值
attr = driver.find_element(By.ID,'kw').get_attribute('type')
print(attr) #返回元素的结果是否可以看见
result = driver.find_element(By.ID,'kw').is_displayed()
print(result) #栗子:鼠标事件
from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.common.action_chains import ActionChains driver = webdriver.Chrome()
driver.get('http://www.baidu.com') #定位到要右击的元素
right_click = driver.find_element(By.ID,'kw')
#对定位的元素执行鼠标右键的操作
ActionChains(driver).context_click(right_click).perform() #定位到要悬停的元素
above = driver.find_element(By.LINK_TEXT,'设置')
#对定位到的元素执行悬停操作
ActionChains(driver).move_to_element(above).perform() #定位到要双击的元素
double_click = driver.find_element(By.XPATH,"//div[@id='lg']")
#对定位到的元素执行双击操作
ActionChains(driver).double_click(double_click).perform() #鼠标推放元素:这个我试用在百度首页,貌似不好用,其他场景没试过
#定位元素的元位置
element = driver.find_element(By.CSS_SELECTOR,"div[class='qrcode-img']")
#定位元素要移动到的目标位置
target = driver.find_element(By.LINK_TEXT,'新闻')
#执行元素的拖放操作
ActionChains(driver).drag_and_drop(element,target).perform() #栗子 键盘操作
from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.common.keys import Keys driver = webdriver.Chrome()
driver.get('http://www.baidu.com') #输入框输入内容
driver.find_element(By.ID,'kw').send_keys('selenium22') #删除多输入的一个22
driver.find_element(By.ID,'kw').send_keys(Keys.BACK_SPACE) #输入空格键 + ‘教程’
driver.find_element(By.ID,'kw').send_keys(Keys.SPACE)
driver.find_element(By.ID,'kw').send_keys(u'教程') #ctrl+a 全选输入框内容
driver.find_element(By.ID,'kw').send_keys(Keys.CONTROL,'a') #ctrl+x 剪切输入框内容
driver.find_element(By.ID,'kw').send_keys(Keys.CONTROL,'x') #ctrl+v 黏贴内容到输入框
driver.find_element(By.ID,'kw').send_keys(Keys.CONTROL,'v') #通过回车键来代替点击操作
driver.find_element(By.ID,'kw').send_keys(Keys.ENTER) #栗子 获得验证信息
from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.common.keys import Keys driver = webdriver.Chrome()
driver.get('http://www.baidu.com') title = driver.title
print(title) now_url = driver.current_url
print(now_url) driver.find_element(By.ID,'kw').send_keys('selenium2')
driver.find_element(By.ID,'su').click() #再次打印当前页面URL
print(driver.current_url)
#再次打印当前页面title
print(driver.title) '''
百度一下,你就知道
https://www.baidu.com/
https://www.baidu.com/s?ie=utf-8&f=8&rsv_bp=0&rsv_idx=1&tn=baidu&wd=selenium2&rsv_pq=b27adbf80000663c&rsv_t=a70btEBJGoDKAin6mRi8AzpsW0eRkwBIOaViQAzDNBiK0EL5CLmW2Z1Onjo&rqlang=cn&rsv_enter=0&rsv_sug3=9&rsv_sug1=1&rsv_sug7=100&inputT=496&rsv_sug4=496
百度一下,你就知道 ''' # 栗子 显式等待
from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC driver = webdriver.Chrome()
driver.get('http://www.baidu.com') element = WebDriverWait(driver,5,0.5).until(EC.presence_of_element_located((By.ID,'kw')))
element.send_keys('selenium22')
【备注】
WebDriverWait()
它是由 webdirver 提供的等待方法。在设置时间内,默认每隔一段时间检测一次当前页面元素是否存
在,如果超过设置时间检测不到则抛出异常。具体格式如下:
WebDriverWait(driver, timeout, poll_frequency=0.5, ignored_exceptions=None)
driver - WebDriver 的驱动程序(Ie, Firefox,Chrome 等)
timeout - 最长超时时间,默认以秒为单位
poll_frequency - 休眠时间的间隔(步长)时间,默认为 0.5 秒
ignored_exceptions - 超时后的异常信息,默认情况下抛 NoSuchElementException 异常。
until()
WebDriverWait()一般由 until()(或 until_not())方法配合使用,下面是 until()和 until_not()方法的说明。
until(method, message=’ ’)
调用该方法提供的驱动程序作为一个参数,直到返回值为 Ture。
until_not(method, message=’ ’)
调用该方法提供的驱动程序作为一个参数,直到返回值为 False。
Expected Conditions
在本例中,我们在使用 expected_conditions 类时对其时行了重命名,通过 as 关键字对其重命名为 EC,
并调用 presence_of_element_located()判断元素是否存在 expected_conditions 类提供一些预期条件的实现
title_is 用于判断标题是否xx
title_contains 用于判断标题是否包含xx信息
presence_of_element_located 元素是否存在
visibility_of_element_located 元素是否可见
visibility_of 是否可见
presence_of_all_elements_located 判断一组元素是否存在
text_to_be_present_in_element 判断元素是否有xx文本信息
text_to_be_present_in_element_value 判断元素值是否有xx文本信息
frame_to_be_available_and_switch_to_it 表单是否可用,并切换到该表单
invisibility_of_element_located 判断元素是否隐藏
element_to_be_clickable 判断元素是否点击,她处于可见和启动状态
staleness_of 等到一个元素不再依附于DOM
element_to_be_selected 被选中的元素
element_located_to_be_selected 一个期望的元素位于被选中
element_selection_state_to_be 一个期望检查如果给定的元素被选中
element_located_selection_state_to_be 期望找到一个元素并检查是否选择状态
alert_is_present 预期一个警告信息
除了 expected_conditions 所提供的预期方法,我们也可以使用前面学过的 is_displayed()方法来判断元
素是否可见 #栗子 隐式等待1
from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.support.ui import WebDriverWait driver = webdriver.Chrome()
driver.implicitly_wait(10) #10秒
driver.get('http://www.baidu.com') input_ = driver.find_element(By.ID,'kw222')
input_.send_keys('selenium')
#结果
#AttributeError: 'NoneType' object has no attribute 'send_keys' #栗子 隐式等待2
from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.support.ui import WebDriverWait driver = webdriver.Chrome()
driver.implicitly_wait(10) #10秒
driver.get('http://www.baidu.com') input_ = driver.find_element(By.ID,'kw')
input_.send_keys('selenium')
#结果,不报错 #栗子 sleep 休眠方法
from selenium import webdriver
from selenium.webdriver.common.by import By
from time import sleep driver = webdriver.Chrome()
driver.get('http://www.baidu.com') sleep(2)
driver.find_element(By.ID,'kw').send_keys('selenium')
driver.find_element(By.ID,'su').click()
sleep(3) #栗子 定位一组元素 在当前文件夹下创建checkbox.html
<html>
<head>
<meta http-equiv="content-type" content="text/html;charset=utf-8" />
<title>Checkbox</title>
<link href="http://cdn.bootcss.com/bootstrap/3.3.0/css/bootstrap.min.css"
rel="stylesheet" />
<script
src="http://cdn.bootcss.com/bootstrap/3.3.0/css/bootstrap.min.js"></script>
</head>
<body>
<h3>checkbox</h3>
<div class="well">
<form class="form-horizontal">
<div class="control-group">
<label class="control-label" for="c1">checkbox1</label>
<div class="controls">
<input type="checkbox" id="c1" />
</div>
</div>
<div class="control-group">
<label class="control-label" for="c2">checkbox2</label>
<div class="controls">
<input type="checkbox" id="c2" />
</div>
</div>
<div class="control-group">
<label class="control-label" for="c3">checkbox3</label>
<div class="controls">
<input type="checkbox" id="c3" />
</div>
</div>
</form>
</div>
</body>
</html> 执行以下代码:
from selenium import webdriver
from selenium.webdriver.common.by import By
import os driver = webdriver.Chrome()
file_path = 'file:///' + os.path.abspath('checkbox.html')
file_path = file_path.replace('\\','/')
driver.get(file_path) #选择页面上所有的tag name 为input 的元素
inputs = driver.find_elements_by_tag_name('input') #然后从中过滤出type 为checkout的元素,单机勾选
for i in inputs:
if i.get_attribute('type') == 'checkbox':
i.click()
# 栗子 定位一组元素 XPATH 和 CSS 方式
from selenium import webdriver
from selenium.webdriver.common.by import By
import os driver = webdriver.Chrome()
file_path = 'file:///' + os.path.abspath('checkbox.html')
file_path = file_path.replace('\\','/')
driver.get(file_path) #通过Xpath找到type=checkbox的元素
checkboxes = driver.find_elements(By.XPATH,"//input[@type='checkbox']") #通过css找到type=checkbox的元素
#checkboxes = driver.find_element(By.CSS_SELECTOR,'input[type=checkbox]') for checkbox in checkboxes:
checkbox.click() #打印当前页面上的type为checkbox的个数
print(len(checkboxes)) #吧页面上最后一个checkbox的钩给去掉
driver.find_elements(By.CSS_SELECTOR,'input[type=checkbox]').pop().click()
#栗子 frame,报错的
from selenium import webdriver
from selenium.webdriver.common.by import By
import os
import time driver = webdriver.Chrome()
file_path = 'file:///' + os.path.abspath('frame.html')
file_path = file_path.replace('\\','/')
driver.get(file_path) #
driver.find_element(By.ID,'kw').send_keys('selenium2')
driver.find_element(By.ID,'su').click()
time.sleep(3)
#【结果】no such element #栗子 frame 正常的 根据id来定位
from selenium import webdriver
from selenium.webdriver.common.by import By
import os
import time driver = webdriver.Chrome()
file_path = 'file:///' + os.path.abspath('frame.html')
file_path = file_path.replace('\\','/')
driver.get(file_path) #切换到iframe(id='if')
driver.switch_to_frame('if') #然后就可以正常操作元素了
driver.find_element(By.ID,'kw').send_keys('selenium2')
driver.find_element(By.ID,'su').click()
time.sleep(3) #栗子 frame 正常的 根据name来定位
from selenium import webdriver
from selenium.webdriver.common.by import By
import os
import time driver = webdriver.Chrome()
file_path = 'file:///' + os.path.abspath('frame.html')
file_path = file_path.replace('\\','/')
driver.get(file_path) #切换到iframe(name='nf')
driver.switch_to_frame('nf') #然后就可以正常操作元素了
driver.find_element(By.ID,'kw').send_keys('selenium2')
driver.find_element(By.ID,'su').click()
time.sleep(3) # 栗子 根据父节点或本节点的其他方式定位
from selenium import webdriver
from selenium.webdriver.common.by import By
import os
import time driver = webdriver.Chrome()
file_path = 'file:///' + os.path.abspath('frame.html')
file_path = file_path.replace('\\','/')
driver.get(file_path) #切换到iframe(name='nf') #根据父节点定位
iframe = driver.find_element(By.XPATH,"//div[@class='span10 well']/iframe")
#根据本节点定位
#iframe = driver.find_element(By.XPATH,"//iframe")
driver.switch_to_frame(iframe) #然后就可以正常操作元素了
driver.find_element(By.ID,'kw').send_keys('selenium2')
driver.find_element(By.ID,'su').click()
time.sleep(3) driver.switch_to_default_content() #栗子 窗口切换
from selenium import webdriver
from selenium.webdriver.common.by import By driver = webdriver.Chrome()
driver.implicitly_wait(10)
driver.get('http://www.baidu.com') #获得百度搜索窗口句柄
search_window = driver.current_window_handle driver.find_element(By.LINK_TEXT,u'登录').click()
driver.find_element(By.LINK_TEXT,u'立即注册').click() #获得当前所有打开的窗口的句柄
all_handles = driver.window_handles #进入注册窗口
for handle in all_handles:
if handle != search_window:
driver.switch_to_window(handle)
print('now register window')
driver.find_element(By.NAME,'userName').send_keys('username___9') #进入搜索窗口
for handle in all_handles:
if handle == search_window:
driver.switch_to_window(handle)
print('now search window')
driver.find_element(By.ID,'TANGRAM__PSP_4__closeBtn').click()
driver.find_element(By.ID,'kw').send_keys('selenium')
driver.find_element(By.ID,'su').click() # 栗子 警告框处理
from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.common.action_chains import ActionChains
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.support import expected_conditions driver = webdriver.Chrome()
driver.implicitly_wait(10)
driver.get('http://www.baidu.com') #鼠标悬停“设置”连接
link = driver.find_element(By.LINK_TEXT,u'设置')
ActionChains(driver).move_to_element(link).perform() #打开搜索设置
driver.find_element(By.CLASS_NAME,'setpref').click() #保存设置
#element = WebDriverWait(driver,5,0.5).until(expected_conditions.element_to_be_clickable((By.CSS_SELECTOR,'#gxszButton>a.prefpanelgo')))
if driver.find_element(By.CSS_SELECTOR,'#gxszButton>a.prefpanelgo').is_displayed():
driver.find_element(By.CSS_SELECTOR, '#gxszButton>a.prefpanelgo').click() # 接收弹窗
driver.switch_to_alert().accept() # 栗子 文件上传 send_keys 实现上传
upfile.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta http-equiv="content-type" content="text/html" charset="UTF-8">
<title>upload_file</title>
<link href="http://cdn.bootcss.com/bootstrap/3.3.0/css/bootstrap.min.css" rel="stylesheet">
<script src="http://cdn.bootcss.com/bootstrap/3.3.0/css/bootstrap.min.js"></script>
</head>
<body>
<div class="row-fluid">
<div class="span6 well">
<h3>upload_file</h3>
<input type="file" name="file" />
</div>
</div> </body>
</html> 脚本
from selenium import webdriver
from selenium.webdriver.common.by import By
import os driver = webdriver.Chrome() #打开上传功能页面
file_path = 'file:///' + os.path.abspath('upfile.html')
file_path = file_path.replace('\\','/')
driver.get(file_path) #定位上传按钮,添加本地文件
driver.find_element(By.NAME,'file').send_keys('D:\\upload_file.txt') #栗子 cookie
from selenium import webdriver
from selenium.webdriver.common.by import By
import os driver = webdriver.Chrome() driver.get('http://www.youdao.com') #获得cookie信息
cookie = driver.get_cookies()
#打印
print(cookie) #结果:
[{u'domain': u'.youdao.com',
u'secure': False,
u'value': u'aGFzbG9nZ2VkPXRydWU=',
u'expiry': 1408430390.991375,
u'path': u'/',
u'name': u'_PREF_ANONYUSER__MYTH'},
{u'domain': u'.youdao.com',
u'secure': False,
u'value': u'1777851312@218.17.158.115',
u'expiry': 2322974390.991376,
u'path': u'/', u'name':
u'OUTFOX_SEARCH_USER_ID'},
{u'path': u'/',
u'domain': u'www.youdao.com',
u'name': u'JSESSIONID',
u'value': u'abcUX9zdw0minadIhtvcu',
u'secure': False}]
#栗子 操作cookie
from selenium import webdriver
from selenium.webdriver.common.by import By
import os driver = webdriver.Chrome() driver.get('http://www.youdao.com') #向cookie的name 和 value 添加回话信息
driver.add_cookie({'name':'key-aaaaaaaa','value':'value-bbbbb'}) #遍历cookies 中的name 和value信息打印,当然还有上面添加的信息
for cookie in driver.get_cookies():
print('%s -> %s' % (cookie['name'],cookie['value']))
#结果
OUTFOX_SEARCH_USER_ID -> -2105560286@220.248.17.218
DICT_UGC -> be3af0da19b5c5e6aa4e17bd8d90b28a|
JSESSIONID -> abcbl2cYr1e9V9KYhHIbw
OUTFOX_SEARCH_USER_ID_NCOO -> 707927902.8917714
___rl__test__cookies -> 1513481263502
key-aaaaaaaa -> value-bbbbb
#栗子 js 页面滚动条
from selenium import webdriver
from selenium.webdriver.common.by import By
import time driver = webdriver.Chrome() driver.get('http://www.baidu.com') #搜索
driver.find_element(By.ID,'kw').send_keys('selenium')
driver.find_element(By.ID,'su').click()
time.sleep(3) #将页面滚动条拖到底部
js = 'var q = document.body.scrollTop=10000'
driver.execute_script(js)
time.sleep(3) #将页面滚动条拖到顶部
js_ = 'var q = document.body.scrollTop=0'
driver.execute_script(js_)
time.sleep(3) # 栗子 窗口截图
from selenium import webdriver
from selenium.webdriver.common.by import By
import time driver = webdriver.Chrome() driver.get('http://www.baidu.com') try:
driver.find_element('kw_error').send_keys('selenium')
driver.find_element('su').click()
except:
driver.get_screenshot_as_file('baidu_error.jpg') # 在当前文件夹下生成错误截图 #栗子 退出
quit()方法,其含义为退出相关的驱动程序和关闭所有窗口
只能关闭其中的某一个窗口,这个时候就需要使用 close()来关闭 #栗子 debug
from selenium import webdriver
import logging
logging.basicConfig(level=logging.DEBUG)
diver = webdriver.Chrome()
diver.get("http://www.baidu.com")
diver.find_element_by_id("kw").send_keys("selenium")
diver.find_element_by_id("su").click() #栗子 【自动化测试模型】【数据驱动】 qq邮箱
from selenium import webdriver
from selenium.webdriver.common.by import By
import time driver = webdriver.Chrome()
driver.implicitly_wait(10)
driver.get("http://mail.qq.com") class Account(object):
def __init__(self,username='',password=''):
self.username = username
self.password = password def do_login_as(user_info):
if driver.find_element(By.CSS_SELECTOR, 'iframe#login_frame').is_displayed():
driver.switch_to.default_content()
driver.switch_to.frame(driver.find_element(By.CSS_SELECTOR, 'iframe#login_frame'))
driver.find_element(By.LINK_TEXT, '帐号密码登录').click()
driver.find_element(By.XPATH, ".//*[@id='u']").clear()
driver.find_element(By.XPATH, ".//*[@id='u']").send_keys(user_info.username)
driver.find_element(By.XPATH, ".//*[@id='p']").clear()
driver.find_element(By.XPATH, ".//*[@id='p']").send_keys(user_info.password)
driver.find_element(By.CSS_SELECTOR, 'input#login_button').click() wxue = Account(username='981094301@qq.com',password='9(zndxcpvsWWXX') #调用登录函数
do_login_as(wxue)
#栗子 【自动化测试模型】【数据驱动】百度搜索
建文件夹,下面两个文件,一个.txt,一个.py
user_info.txt
zhangsan,123
lisi,456
wagnwu,789 test.py
from selenium import webdriver user_file = open('user_info.txt','r')
values = user_file.readlines()
user_file.close() for search in values:
username = search.split(',')[0]
print(username)
password = search.split(',')[1]
print(password) #栗子 【自动化测试模型】【数据驱动】读取csv文件
.csv 文件,在pycharm中的文件内容显示如下:
username,password
testing,123@126.com
testing1,123@qq.com
.py 文件:
from selenium import webdriver
import csv
#获取csv文件中password列
with open(r'info.csv','r',encoding='utf-8') as csvfile:
text=csv.DictReader(csvfile)
pwd=[row['password'] for row in text]
#获取csv文件中username列
with open(r'info.csv','r',encoding='utf-8') as csvfile:
text=csv.DictReader(csvfile)
user=[row['username'] for row in text]
#打印出来以列表形式,也可以获取单条数据
print(user,pwd) #结果
['testing', 'testing1'] ['123@126.com', '123@qq.com']
# 常用方法
assertIs(first, second, msg=None)
assertIsNot(first, second, msg=None)
测试第一个和第二个是否为同一对象。
assertIsNone(expr, msg=None)
assertIsNotNone(expr, msg=None)
测试表达式是否为 None 对象。
assertIsInstance(obj, cls, msg=None)
assertNotIsInstance(obj, cls, msg=None)
测试对象(obj)是否有一个实例(cls)
【selenium2】【selenium基础语法】的更多相关文章
- Python+Selenium基础入门及实践
Python+Selenium基础入门及实践 32018.08.29 11:21:52字数 3220阅读 23422 一.Selenium+Python环境搭建及配置 1.1 selenium 介绍 ...
- Swift与C#的基础语法比较
背景: 这两天不小心看了一下Swift的基础语法,感觉既然看了,还是写一下笔记,留个痕迹~ 总体而言,感觉Swift是一种前后端多种语言混合的产物~~~ 做为一名.NET阵营人士,少少多多总喜欢通过对 ...
- iOS-----正则表达式的基础语法
正则表达式简单语法总结 一.什么是正则表达式 从概念上来说,正则表达式也是一门小巧而精炼的语言,它可以用来简化检索特定的字符串,替换特定字符等功能,有许多开发语言工具,都内嵌支持正则表达式.那么一个正 ...
- python之最强王者(2)——python基础语法
背景介绍:由于本人一直做java开发,也是从txt开始写hello,world,使用javac命令编译,一直到使用myeclipse,其中的道理和辛酸都懂(请容许我擦干眼角的泪水),所以对于pytho ...
- emmet 系列(1)基础语法
emmet 系列(1)基础语法 emmet 是一个能显著提升开发html和css开发效率的web开发者工具 emmet基本上目前已知的编辑器都有相应的插件,各个编辑器的emmet插件的下载地址:点我下 ...
- Scala基础语法 (一)
如果你之前是一名 Java 程序员,并了解 Java 语言的基础知识,那么你能很快学会 Scala 的基础语法. Scala 与 Java 的最大区别是:Scala 语句末尾的分号 ; 是可选的. 我 ...
- Java基础语法
java基础学习总结——基础语法1 一.标识符
- javascript中正则表达式的基础语法
× 目录 [1]定义 [2]特点 [3]元字符[4]转义字符[5]字符组[6]量词[7]括号[8]选择[9]断言[10]模式[11]优先级[12]局限性 前面的话 正则表达式在人们的印象中可能是一堆无 ...
- Swift基础语法学习总结(转)
Swift基础语法学习总结 1.基础 1.1) swift还是使用// 和/* */ 来注释,并且/* */允许多行注释. 1.2) swift使用print和println打印,它的传参是一个泛型 ...
随机推荐
- mysql-day06
##视图 - 什么是视图:在数据库中存在多种对象,表和视图都是数据库中的对象,创建视图时名称不能和表重名,视图实际上就代表一段sql查询语句,也可以理解成视图是一张虚拟的表,此虚拟表中的数据会随着原表 ...
- [转载]Oracle PL/SQL之LOOP循环控制语句
在PL/SQL中可以使用LOOP语句对数据进行循环处理,利用该语句可以循环执行指定的语句序列.常用的LOOP循环语句包含3种形式:基本的LOOP.WHILE...LOOP和FOR...LOOP. LO ...
- input 的radio checkbox 和 select 相关操作
1 select 获取和设置值,以及onchange事件 1下拉框option没有checked事件 可通过select 的 onchange事件进行监控,以获取其值 <select name ...
- GoldenGate 12.3微服务架构与传统架构的区别
随着Oracle GoldenGate 12c(12.3.0.1.0)的发布,引入了可用于复制业务数据的新架构. 多年来,这种架构有着不同的称谓,Oracle终于在最后GA发布的版本中,以“Micro ...
- Service_name 和Sid的区别
Service_name:该参数是由oracle8i引进的.在8i以前,使用SID来表示标识数据库的一个实例,但是在Oracle的并行环境中,一个数据库对应多个实例,这样就需要多个网络服务名,设置繁琐 ...
- Linux 安装 mysql 数据库
1. 克隆虚拟机 2. 上传安装文件 1.上传文件 2.解压文件 tar -xvf 文件 3. 安装数据库 安装顺序: .debuginfo .shared .client .server 1. rp ...
- Docker MySQL5.5镜像
定制MySQL的镜像有个很大的难题:mysqld启动之前要初始化数据目录,5.5自带有空账号密码需要初始化. Dockerfile FROM centos # 拷贝需要的安装和MySQL初始脚本 CO ...
- curl 抓取图片
/** * curl 抓取图片 * @param $url * @return mixed */ public static function downLoadImage($url) { $heade ...
- Windbg解决系统蓝屏
win10企业版连续两天遭遇系统蓝屏, 今天就各种检查,准备好好地研究一下这个问题,以下是整个过程: 首先,找到系统蓝屏时的错误日志: [计算机] --> [管理] --> [系统工具] ...
- springmvc StringHttpMessageConverter 中文乱码的几种解决办法(亲测)
昨天,将一个原来使用JSR 311作为restful实现的测试系统改成了使用spring mvc,最后测试的时候发现输出的json字符串为乱码,从日志可以看出使用的是StringHttpMessage ...