JMeter整理教程.docx_第1页
JMeter整理教程.docx_第2页
JMeter整理教程.docx_第3页
JMeter整理教程.docx_第4页
JMeter整理教程.docx_第5页
已阅读5页,还剩29页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

JMeter教程 整理者:珊瑚JMeter整理教程1. 下载安装Jmeter1.1 下载Jmeter下载地址:/download_jmeter.cgi目前最新版为2.9,其余文件如源代码等也可从如下官网下载:/download_jmeter.cgi1.2 环境配置安装Jmeter之前需要先配置Java环境,我们下载的是jmeter2.9,所以java版本最好是选用java6以后的版本。安装JDk1.6的步骤如下:点击下载的JDK文件-dk-6u18-windows-i586.exe,点击下一步直至安装完成,然后开始配置环境:点击我的电脑-属性-高级-环境变量-在系统变量中-点击新建,在变量名中输入:JAVA_HOME变量值中输入:C:ProgramFiles(x86)Javajdk1.6.0_18这里注意,不需要加“;”,我加了“;”结果导致javac命令无效。再次点击新建:在变量名中输入:CLASSPATH,变量值中输入:.;%JAVA_HOME%/lib/dt.jar;%JAVA_HOME%/lib/tools.jar;然后再系统变量中找到Path,点击编辑,在变量值中加上:%JAVA_HOME%/bin;%JAVA_HOME%/jre/bin;(如果前面没有“;”需要加上)配置完成之后,点击确定保存,然后cmd打开命令窗口输入:java或者javac,出现大串字符串表示配置成功。也可以输入:java-version查看java版本来查看是否配置成功。OK,JDK安装成功之后,就可以下一步安装Jmeter了。1.3 安装Jmeter解压apache-jmeter-2.9.zip文件至目录,我的是D:ProgramFiles目录。点击我的电脑-属性-高级-环境变量-在系统变量中-点击新建,变量名输入:JMETER_HOME变量值输入:D:ProgramFilesapache-jmeter-2.9然后编辑CLASSPATH变量,加上%JMETER_HOME%libextApacheJMeter_core.jar;%JMETER_HOME%libjorphan.jar;%JMETER_HOME%liblogkit-2.0.jar;然后确定即可操作完上面的步骤,我们就可以点击Jmeter中bin目录下面的jmeter.bat文件即可打开Jmeter了。注意:打开的时候会有两个窗口,Jmeter的命令窗口和Jmeter的图形操作界面,不可以关闭命令窗口。界面如下图所示:2. 录制和运行脚本录制Jmeter脚本有两种方法,一种是设置代理;一种则是利用badboy软件,badboy软件支持导出jmx脚本。这里我们介绍第二种方法,利用badboy录制脚本,然后导出Jmeter需要的jmx文件。首先,在地址栏中输入要录制脚本的地址,然后点击绿色按钮即可开始录制(工具栏中的红色按钮也可以点击进行录制),点击红色圆形按钮旁边的正方形黑色按钮结束脚本录制(如果使用过loadrunner,那么步骤是一样的),在内嵌的浏览器上面操作你需要测试的动作即可,它会自己记录你的相关行为动作。然后点击黑色按钮录制完成之后,我们可以导出jmx文件:保存为“登录开发者.jmx”。3. 使用Jmeter开始测试3.1 打开脚本用Jmeter打开我们上面保存的文件。打开之后如图所示:4. 配置元件4.1 HTTPCookie 管理器获得cookie中的JSESSIONID第一步:登录画面,路径选择“跟踪重定向”、“Use KeepAlive”第二步:运行脚本,查看“查看结果树”登录画面JSESSIONID的值。配置cookie中JSESSIONID的值第一步:将登录画面JSESSIONID的值配置到cookie中。第二步:禁用登录画面第三步:清空全部,再次运行。然后查看“查看结果树”中的请求和响应数据。如果响应数据返回结果不是首页,为该画面的内容,则成功。4.2 CSV Data Set Config参数化如下面图,我们为请求发送的参数来参数化。上述的例子为登录的用例,登录有两个参数:EMAIL和DEVELOPER_PASSWORD,在实际测试中,当我们需要用到不同的用户来登录的时候,我们就可以用到参数化。1)、我们新建一个文件,这里我新建的是一个txt文件,命名为c.txt,里面的内容为,111111,111111,1111112)、在jmeter中的【选项】中选择【函数助手对话框】,将会弹出如下对话框:其中:CSVfiletogetvaluesfrom|*alias:要读取的文件路径,为绝对路径CSV文件列号|next|*alias:从第几列开始读取,注意第一列是0如上图所示,我们读取的是c.txt里面的第一列用户名(如果要读取第二列的密码,只需将0改成1即可,往后类推),点击【生成】按钮即可生成函数,我们使用时即拷贝生成的函数字符串:$_CSVRead(E:c.txt,0)。5. 线程组在测试计划里面选择添加既可以看到线程组。如上图:名称:可以随意取,我们保持创建是自动分配的名称注释:随意在取样器错误后要执行的动作:我们选择继续,错误之后依然继续执行线程数:一般我们用来表示多少个用户,即我们测试时的用户数量Ramp-upPeriod(inSeconds):表示每个用户启动的延迟时间,上述我设为1秒,表示系统将在1秒结束前启动我设置的1000个用户,如果设置为1000秒,那么系统将会在1000秒结束前启动这1000个用户,开始用户的延迟为1秒,如果我设置为0秒,则表示立即启动所有用户。循环次数:如果你要限定循环次数为10次的话,可以取消永远的那个勾,然后在后面的文本框里面填写10;在这里我们勾上永远,表示如果不停止或者限定时间将会一直执行下去,是为了方便调度器的调用。调度器的配置:我们勾选调度器时,将会出现这个面板启动时间:表示我们脚本开始启动的时间,当你不想立即启动脚本测试,但是启动脚本的时间不会再电脑旁的时候,你可以设定一个启动的时间,然后再运行那里点击启动,系统将不会立即运行,而是会等到你填写的时间才开始运行。结束时间:与启动时间对应,表示脚本结束运行的时间。持续时间:表示脚本持续运行的时间,以秒为单位,比如如果你要让用户持续不断登录1个小时,你可以在文本框中填写3600。如果在1小时以内,结束时间已经到达,它将会覆盖结束时间,继续执行。启动延迟:表示脚本延迟启动的时间,在点击启动后,如果启动时间已经到达,但是还没有到启动延迟的时间,那么,启动延迟将会覆盖启动时间,等到启动延迟的时间到达后,再运行系统。注意:如果我们需要用到调度器来设定持续时间,如果线程数不够多到持续时间结束,我们就必须将循环次数勾选为永远,特别地,如果线程组里面有其他的循环,我们也需将该循环次数勾选为永远(如我上面录制的脚本中的Step1也是一个循环,需要将永远勾选),否则,按我如上配置,将永远去掉勾选,文本里填1,那么无论你将持续时间启动时间结束时间等设置多少,系统运行1000次后,将会停止不再运行。6. Sampler6.1 Http请求关于HTTP请求,我们录制的脚本里面就有,这里就介绍一些常用的属性。如图所示:点击HTTP请求,将会出现如下界面:其中:名称:可以随意取,我们可以根据录制脚本的路径来命名注释:可以对该界面做一个简单介绍服务器名称或IP:即我们的服务器或者IP的地址,我因为是在本机上的项目,故填写localhost,可以填写。端口号:我用的是tomcat,自己设置的端口号为8086(tomcat默认为8080)后面的超时定义可以不用填写。Implementation:这里我们录制时默认填写为JAVA协议填写为:http方法为:GETContentencoding:编码可以不用填写路径:即页面的路径;下面的重定向等选择可以根据需要勾选,这里我们保持录制不修改。Parameters参数:即跟着路径一起发送的参数及文件下面的代理服务器等可以忽略,按需要填写。7. 定时器7.1 集合点集合点:简单来理解一下,虽然我们的“性能测试”理解为“多用户并发测试”,但真正的并发是不存在的,为了更真实的实现并发这感念,我们可以在需要压力的地方设置集合点,还拿那个用户和密码的地方,每到输入用户名和密码登录的地方,所有的虚拟用户都相互之间等一等,然后,一起访问。首先创建脚本,然后在需要集合测试的请求线程组添加集合点,点击【线程组】-【添加】-【定时器】-【Synchronizing Timer】。进入定时器页面进行设置。Number of Simulated Users to Group by:表示集合多少个用户开始访问Timeout in milliseconds: 如果设置为0,Timer将会等待线程数达到了Number of Simultaneous Users to Group中设置的值才释放。如果大于0,那么如果超过Timeout in milliseconds中设置的最大等待时间(毫秒为单位)后还没达到Number of Simultaneous Users to Group中设置的值,Timer将不再等待,释放已到达的线程。默认为0 。注意:如果设置Timeout in milliseconds为0,且线程数量无法达到Number of Simultaneous Users to Group by中设置的值,那么Test将无限等待,除非手动终止。Synchronizing timer 仅作用于同一个JVM中的线程,所以,如果使用并发测试,确保Number of Simultaneous Users to Group by中设置的值不大于它所在线程组包含的用户数。如果希望定时器仅应用于其中一个sampler,则把该定时器作为子节点加入 ,如下图所示。8. 逻辑控制器jmeter中逻辑控制器(Logic Controllers)的作用域只对其子节点的sampler有效,作用是控制采样器的执行顺序。jmeter提供了17种逻辑控制器,它们各个功能都不尽相同,大概可以分为2种使用类型:.控制测试计划执行过程中节点的逻辑执行顺序,如:Loop Controller(循环控制器)、If Controller(如果if控制器)等;.对测试计划中的脚本进行分组,方便JMeter统计执行结果以及进行脚本的运行时控制等,如:Throughput Controller(吞吐量控制器)、Transaction Controller(事务控制器)等jmeter提供如下17种逻辑控制器:8.1 临界区控制器(critical section Controller)作用:临界区控制器确保其子节点下的取样器或控制器将被执行(只有一个线程作为一个锁)名称和注释很简单,就是给控制器添加一个备注,使人明白这个控制器的解释含义的意思Lock name:锁名称,这里可以填入其子节点下执行的线程的名称,这个线程作为一个全局锁存在8.2 遍历循环控制器(ForEach Controller)作用:用来遍历当前元素的所有可执行场景;在用户自定义变量中读取一系列相关的变量,该控制器下的采样器或控制器都会被执行一次或多次,每次读取不同的变量值,所以它总是和用户自定义变量一起使用输入变量前缀:在其中输入需要遍历的用户参数(User Parameter)Start index for loop(exclusive):循环指数开始(唯一) 遍历查询的变量范围,开始的值(这里如果不填写,默认从1开始,如果没有1开始的变量,执行时会报错)End index for loop(inclusive):循环指数结束(包含) 遍历查询的变量范围,结束的值输出变量名称:将遍历查询到的符合条件的用户参数赋值给输入变量(Vname),然后就可以在控制器下的取样器使用,格式为$输出变量名Add”_”before number:输入变量名称中是否使用“_”进行间隔PS:这个控制器一般配合配置元件 用户定义的变量来一起使用8.3 包含控制器(Include Controller)作用:用于引用外部的Jmx文件;从而控制多个测试计划组合include Test Plan:包含测试计划的文件名,可以点击浏览,从文件夹保存的JMX文件夹目录下选择对应的JMX文件使用方法:创建一个测试计划,下面可添加取样器/控制器等,然后保存测试计划,为了方便起见,线程组也可以添加外部JMX文件中用于调试;如果测试使用Cookie或用户定义的变量,这些应放置在顶层(包括文件),否则无法正常工作;此元素不支持变量/函数在文件名字段中;但是,如果属于包含控制器定义的内容,则使用前缀路径名。当使用包含控制器中包含相同的JMX文件,则要确保文件名不同,以避免无法读取;如果文件不能被发现,那么控制器会尝试打开文件名相对于JMX启动目录。8.4 生命周期/运行周期控制器(Runtime Controller)作用:用于控制该控制器下的取样器/控制器的运行时间Runtime(seconds):运行时间,单位为:秒8.5 转换控制器(Switch Controller)作用:通过给该控制器中的value赋值,来指定运行哪个取样器(也可以理解为开关控制器)Switch value:控制器具体赋值的value值字段有两种赋值方式:第一种是数值,Switch控制器下的子节点从0开始计数,通过指定子节点所在的数值来确定执行哪个元素。第二种是直接指定子元素的名称,比如采样器的Name来进行匹配。当指定的名称不存在时,不执行任何元素。当Value为空时,默认执行第1个子节点元素。8.6 当/判断控制器(While Controller)作用:运行其子节点下的取样器/控制器,直到条件为“假”Condition(function or variable):条件(函数或变量):里面可填入判断依据的条件,参照使用方法:可能的条件值有:.空白:最后一个示例循环失败时退出循环.最后一个值:最后一个示例循环失败时退出循环。 如果之前的最后一个示例只是循环失败,不进入循环。.否则:退出时(或不输入)循环条件等于字符串“假”条件可以是任何变量或函数,最终等于字符串”假”。需要注意的是:条件是评估两次,一次取样前,一次随机取样8.7 事务控制器(transaction controller)作用:生成一个额外的采样器来测量其下测试元素的总体时间;值得注意的是,这个时间包含该控制器范围内的所有处理时间,而不仅仅是采样器的Generate parent sample:生成父样本(不同的模式选择)include duration of timer and pre-post processors in generated sample:包含时间的计时器和前后处理器生成的示例(不同的模式选择)对于Jmeter2.3以上的版本,有两种模式的操作.事务采样器是添加到其下采样器后面的.事务采样器是作为其下采样器的父采样器生成的事务采样器的测量的时间包括其下采样器以及其他的一切时间。由于时钟频率问题,这个时间可能略大于单个采样器的时间之和;时钟开始时间介于控制器记录开始时间与第一个采样器开始之间,时钟结束时间亦然。事务采样器只有在其子采样器都成功的情况下才显示成功。在父模式下,事务控制器下的各个采样器只有在结果树里才能看到;同时,子采样器的数据也不会在CSV文件中显示,但是在XML文件中可以看到。8.8 交替控制器(creatleave controller)作用:交替控制,使得该控制器包含的取样器步骤交错执行在每个循环中忽略子控制器模块(Ignore sub-contorller blocks):如果勾选此项,交错控制器将sub-controllers像单一请求元素一样,一次只允许一个请求/控制器使用方法:假使该控制器下有2个取样器A和B,交替执行A和B2个请求,即每次传递一个子请求到这个测试,按子元件的排列顺序8.9 仅一次控制器(once only controller)作用:在多线程循环的时候,将使其子节点下的取样器请求只运行一次8.10 流量控制器(throughput controller)作用:jmeter自带的翻译这里是错误的,因为它并不能控制吞吐量(吞吐量的概念请自行百度);其实质作用是允许用户控制执行的频率总共有两种执行模式:百分比执行和总执行总执行(Total Executions):使控制器停止执行一定数量的测试计划百分比执行(Percent Executions):使控制器按一定比例执行迭代的测试计划流量(Throughput):对应上面的执行数量或者比例每个用户(Per User):每个用户如果勾选此项,将导致控制器计算是否应该执行在每个用户(每个线程)的基础上;如果不加以控制,那么将计算全球所有用户8.11 如果控制器(If Controller)作用:允许用户控制该控制器下面的取样器/控制器是否执行测试条件(默认JavaScript)(Condition(default javascript)):使用JavaScript的函数或变量进行评估判断条件为真或假条件解释为变量表达式(interpret condition as variable expression):如果勾选该项,那么变量表达式会进行求值,并与“ture”或“false”进行比较,而无需使用JavaScript对所有子条件评估(evaluate for all children):如果勾选该项,则变量表达式可以返回任何值,而不用与“ture”或“false”进行比较默认情况下,该控制器可以对包含在其下面的所有可运行的元素进行评估,但只能评估一次填写多个条件并用“,”号隔开时表示且的关系,只有所有条件同时满足才可运行。8.12 录制控制器(Recording Controller)作用:类似代理服务器的作用,在测试执行期间记录测试样本清除所有记录的样本(Clear all the recorded samples):点击可以清除所有已经记录的测试样本一般情况下,在测试执行时候,它没有效果,但是在执行HTTPS测试脚本时,会记录下所有测试样本8.13 循环控制器(Loop Controller)作用:该控制器下的取样器请求可以循环运行循环次数(Loop Count):在输入框中输入需要循环的次数,控制器下的请求即可循环运行永远(forever):如果勾选该项,那么控制器下的请求可一直运行8.14 模块控制器(Module Controller)作用:测试控制器子节点下的某一个模块,而不是整个测试计划寻找目标元素(Find target element):寻找测试计划中需要特定测试的元素,模块;也可理解为该控制器可以控制已经封装好的模块元素 :一个测试计划由一个控制器和所有的测试元素(取样器等)组成,测试计划可以位于任何线程组或工作台;如果计划位于线程组,则可以禁用其他控制器,防止正在运行的测试计划被影响(除了模块控制器) 模块控制器的优势在于:当存在多个线程组时,该控制器可以轻松切换,只需要选择对应的取样器,方便快捷,替代了创建很多测试计划的繁琐操作 :任何一个模块所用的控制器名字必须唯一,因为其名字被用来找到目标控制器时重新加载;出于这个原因,最好保证控制器名字不同,否则执行测试时候可能发生意外 :模块控制器与远程测试不应使用或非gui测试与工作台部件,因为工作台测试元素并没有测试计划的一部分jmx文件。 任何这样的测试就会失败8.15 简单控制器(Simple Controller)作用:用来组合取样器和其他逻辑控制器简单控制器是最基本的控制器,对jmeter测试运行没有任何影响,可用来命名某些操作8.16 随机控制器(Random Controller)作用:类似交替控制器,但该控制器随机选取某一个取样器请求并执行忽略子控制器模块(Ignore sub-controller blocks):如果勾选此项,交错控制器将sub-controllers像单一请求元素一样,一次只允许一个请求/控制器8.17 随机顺序控制器(Random Order Controller)作用:类似于简单控制器,将执行每个每个子节点下的取样器请求一次,但是执行是随机的9. 后置处理器9.1 正则表达式提取器Jmeter关联的方式Jmeter中关联可以在需要获取数据的请求上 右键-后置处理器 选择需要的关联方式,如下图有很多种方法可以提取动态变化数据:正则表达式提取器1、比如需要提取如下响应文本中的 “百度一下,你就知道” 里面的 “百度一下,你就知道”:2、设置正则表达式提取器:说明:(1)引用名称:下一个请求要引用的参数名称,如填写title,则可用$title引用它。(2)正则表达式:():括起来的部分就是要提取的。.:匹配任何字符串。+:一次或多次。?:不要太贪婪,在找到第一个匹配项后停止。(3)模板:用$引用起来,如果在正则表达式中有多个正则表达式,则可以是$2$3$等等,表示解析到的第几个值给title。如:$1$表示解析到的第1个值(4)匹配数字:0代表随机取值,1代表全部取值,通常情况下填0(5)缺省值:如果参数没有取得到值,那默认给一个值让它取。3、使用2中获取到的值:关于正则表达式的举例说明1、提取单个字符串:假如想匹配Web页面的如下部分:name = file value = readme.txt并提取readme.txt。一个合适的正则表达式:name = file value = (.+?)。():封装了待返回的匹配字符串。.:匹配任何单个字符串。+:一次或多次。?:不要太贪婪,在找到第一个匹配项后停止。2、提取多个字符串:假如想匹配Web页面的如下部分:name = value = readme.txt并提取和readme.txt。一个合适的正则表达式:name = (.+?) value = (.+?)。这样就会创建2个组,分别用于$1$和$2$比如:引用名称:MYREF模板:$1$2$如下变量的值将会被设定:MYREF: readme.txtMYREF_g0:name = value = readme.txtMYREF_g1:MYREF_g2:readme.txt在需要引用地方可以通过:$MYREF, $MYREF_g1进行使用。10. 断言在web测试中,有的时候,即使我们测试返回的responsecode为200,也不能保证该测试是正确的,这时候,我们可以用到响应断言,通过对比响应的内容来判断返回的页面是否是我们确定要返回的页面。选择我们要判断的页面,点击添加断言-响应断言,将会出现如下图:名称:随意,这里我们不做改动注释:随意Applyto:这里我们选择默认值要测试的响应字段:这里我们选择响应的文本,即返回的页面信息模式匹配规则:这里我们选择包括,即响应的文本是否包括我们验证的信息要测试的模式:开发者名称,即我们需要验证,开发者名称是否在响应文本中存在,也可以添加更多的字段来验证。11. 监听器我们做性能测试的时候,经常需要各种数据来验证我们的测试结果,Jmeter里面也提供了相关的功能,这里主要说一下AggregateReport聚合报告。点击添加-监听器,选择:查看结果树,和聚合报告,如果需要看到断言信息也可以选择断言结果,将设置的一切保存之后,然后点击启动,系统将会运行,将结果在监听器中表现出来。12. 分析结果12.1 查看结果树如图所示:成功的为绿色,失败则显示为红色。如果测试的结果太多,你只需要看到错误的页面,则勾选【仅日志错误】12.2 聚合报告(AggregateReport)其中:Label:标签,即我们上面的请求名称#Samples:本次场景中一共发出了多少个请求Average:平均响应时间Median:中位数,也就是50%的用户的响应时间90%Line:表示90%的用户的响应时间,如果最小值和最大值相差很大的话,我们一般选择这个作为最终测试结果Min:最小响应时间Max:最大响应时间Error%:出错率,本次测试中出现错误的请求的数量/请求的总数Throughput:吞吐量KB/sec:每秒从服务器端接受到的数据量12.3 结果分析(监听器)1.聚合报告Aggregate Report是JMeter常用的一个Listener,中文被翻译为“聚合报告”。今天再次有同行问到这个报告中的各项数据表示什么意思,顺便在这里公布一下,以备大家查阅。如果大家都是做Web应用的性能测试,例如只有一个登录的请求,那么在Aggregate Report中,会显示一行数据,共有10个字段,含义分别如下。Label:每个JMeter的element(例如HTTP Request)都有一个Name属性,这里显示的就是Name属性的值#Samples:表示你这次测试中一共发出了多少个请求,如果模拟10个用户,每个用户迭代10次,那么这里显示100Average:平均响应时间默认情况下是单个Request的平均响应时间,当使用了Transaction Controller时,也可以以Transaction为单位显示平均响应时间Median:中位数,也就是50用户的响应时间90% Line:90用户的响应时间Note:关于50和90并发用户数的含义,请参考下文/jackei/archive/2006/11/11/557972.htmlMin:最小响应时间Max:最大响应时间Error%:本次测试中出现错误的请求的数量/请求的总数Throughput:吞吐量默认情况下表示每秒完成的请求数(Request per Second),当使用了Transaction Controller时,也可以表示类似LoadRunner的Transaction per Second数KB/Sec:每秒从服务器端接收到的数据量,相当于LoadRunner中的Throughput/Sec2. 图形报表图表底部参数的含义如下:样本数目是总共发送到服务器的请求数。最新样本是代表时间的数字,是服务器响应最后一个请求的时间。吞吐量是服务器每分钟处理的请求数。平均值是总运行时间除以发送到服务器的请求数。中间值是代表时间的数字,有一半的服务器响应时间低于该值而另一半高于该值。偏离表示服务器响应时间变化、离散程度测量值的大小,或者,换句话说,就是数据的分布。3. 监视器结果“监视器结果”(Monitor Result)是为Tomcat 5设计的,用来实时反映服务器的性能情况,如果你的AppServer不是Tomcat 5,使用“监视器结果”得不到结果,但是任何servlet container都可以移植status servelet并使用此monitor,如果需要对其他的AppServer使用该Monitor,需要移植Tomcat 5的status servelet。添加JMeter的“监视器结果”利用的是Tomcat本身的特性,就是直接访问Tomcat服务器的/manager/status,获得相应的服务器状态数据并进行呈现。因此,在JMeter中添加“监视器结果”来监视服务器状态的步骤如下:1.增加一个HTTP Request的Sampler;2.选中该新增的HTTP Request,修改其属性:修改“名称”为服务器状态(非必须)修改“路径”为manager/status,必要时给出服务器的IP地址和Port的值增加一个参数,该参数的名称为大写的XML,值为小写的true选中下方的“用作监视器”如下图所示:3.增加一个“http授权管理器”因为访问Tomcat的应用服务器的/manager/status需要给出用户名和口令。如下图所示4.添加一个“监视器结果”的节点执行后,会在监视器结果中的性能页面显示图。其中healthy/Warning/非活动”是根据服务器上的可用线程数/最大可用线程数得出,而Load用

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论