
2、用sqlplus命令进态芹入SQL命令状态,命令行如下:c:\sqlplus/nolog
3、用弯闭悔如下命令连接数据库:connect 数据库用户名/密码@sid_ip,如:sql>connectionljm/ljm@ljm_localhost(本机数据库)
4、用如下命令执行脚本文件sql>@完整路径文件名
5、如果要导入SEQUENCE的话,可以用toad工具埋正先生成SEQ脚本文件,再用如上命令导入
在c语言中调�.shellå½ä»¤çæ¹æ³å®ç°ãcç¨åºè°ç¨shellèæ¬å ±æä¸¤ç§æ¹æ³
ï¼system()ãpopen()ï¼åå«å¦ä¸ï¼
system()
ä¸ç¨èªå·±å»å建è¿ç¨ï¼ç³»ç»å·²ç»å°è£ äºè¿ä¸æ¥ï¼ç´æ¥å å ¥èªå·±çå½ä»¤å³å¯
popen()
ä¹å¯ä»¥å®ç°æ§è¡çå½ä»¤ï¼æ¯system
å¼éå°
以ä¸åå«è¯´æï¼
1ï¼system(shellå½ä»¤æshellèæ¬è·¯å¾ææ¶è¿)
system()
ä¼è°ç¨fork()产ç
ååç¨ï¼ç±ååç¨æ¥è°ç¨/bin/sh-c
stringæ¥å±¥è¡
åæ°stringå符串æä»£è¡¨çå½ä»¤ï¼æ¤å½ä»¤å±¥è¡
å®åéå³è¿ååè°ç¨çåç¨ãå¨è°ç¨ç©ºæ¢system()æé´sigchld
ä¿¡å·ä¼è¢«ææ¶æç½®ï¼sigintåsigquit
ä¿¡å·åä¼è¢«æ¼ è§
ã
è¿
åå¼ï¼å¦æsystem()å¨è°ç¨/bin/shæ¶å¤±è´¥åè¿å127ï¼å ¶ä»å¤±è´¥åå è¿å-1ãè¥åæ°string为空æé(null)ï¼åè¿åéé¶å¼ã
妿
system()è°ç¨æå
åæåä¼è¿åå±¥è¡
shellå½ä»¤åçè¿åå¼ï¼ä½æ¯æ¤è¿åå¼ä¹æå¯è½ä¸ºsystem()è°ç¨/bin/sh失败æè¿åç127ï¼å
æ¤æå¥½è½ååç
errno
æ¥ç¡®è®¤å±¥è¡
æå
ã
systemå½ä»¤ä»¥å ¶ç®ç¥
髿çä½ç¨å¾å°å¾å¾å¹¿æ³
çå©ç¨
ï¼ä¸é¢æ¯ä¸ä¸ªä¾å
ä¾ï¼å¨/tmp/testdir/ç®å½ä¸æshellèæ¬tsh.shï¼å 容为
#!/bin/sh
wget
$1
echo
"done!"
2ï¼popen(char
*command,char
*type)
popen()
ä¼è°ç¨fork()产ç
ååç¨ï¼ç¶åä»ååç¨ä¸è°ç¨/bin/sh
-cæ¥å±¥è¡
åæ°commandçæä»¤ãåæ°typeå¯åºç¨
ârâ代表读åï¼âwâ代表åå ¥ãéµå¾ªæ¤typeå¼ï¼popen()ä¼å»ºç«
管éè¿å°ååç¨çæ å
è¾åºè®¾å¤
ææ å
è¾å ¥è®¾å¤
ï¼ç¶åè¿åä¸ä¸ªæä»¶æéãéååç¨ä¾¿å¯å©ç¨
æ¤æä»¶æéæ¥è¯»åååç¨çè¾åºè®¾å¤
ææ¯åå ¥å°ååç¨çæ å
è¾å ¥è®¾å¤
ä¸ãæ¤å¤ï¼ææåºç¨
æ
ä»¶æé(file*)æä½ç彿°ä¹é½å¯ä»¥åºç¨
ï¼é¤äºfclose()以桥éå¤ã
è¿åå¼ï¼è¥æå
åè¿åæä»¶æéï¼å¦åè¿ånullï¼å·®é
åå åäºerrnoä¸ã注æï¼å¨ç¼åå ·suid/sgidæéçç¨åºæ¶è¯·å°½éé¿å åºç¨
popen()ï¼popen()ä¼ç»§æ¿ç¯å¢åéï¼éè¿ç¯å¢åéå¯è½ä¼é æç³»ç»å®å ¨çé®é¢ã
ä¾ï¼cç¨åºpopentest.cå 容å¦ä¸ï¼
#include
main
{
file
*
fp
charbuffer[80]
fp=popen(â~/myprogram/test.shâ,ârâ)
fgets(buffer,sizeof(buffer),fp)
printf(â%sâ,buffer)
pclose(fp)
}
在C/C++源码中执行shell命令,最基本的就是 system() C库函数,其次可以使用系统提供的api函数,比如windows上的createprocess shellexecuteex等凳袭函数,在linux上可以使用exec()等等.悉亏下面是我在windows上的弄的一个测试版本,使用了线程,我感觉用nc来测试,不如直接 netstat -an | findstr /I "udp" | findstr "22" ,因为22端口太其特了,很容易抓出来. 另外nc判断端口常规的作法就是 nc -vv ip port 看提示信息就好了.
#include <stdio.h>
#include <stdlib.h>
#include <tchar.h>
#include <windows.h>
#include <process.h>
UINT __stdcall ThreadFunc(LPVOID lpParam) {
//将hacker字符串做为nc提交的数据
int ret = system("echo hacker | nc.exe -u 127.1 22")
//ret==0说明没有开启22端口
if (ret == 0 ) printf("nc: Write error: Connection refused.\n")
return 0
}
int main()
{
HANDLE hThread = (HANDLE)_beginthreadex(0, 0, ThreadFunc, 0, 0, 0)
//等待3秒钟,说明22端口可用睁粗神
WaitForSingleObject(hThread, 3000)
//结束测试线程
TerminateThread(hThread, 0)
//重新开启NC连接22端口
system("nc.exe -vv -u 127.1 22")
return 0
}
欢迎光临0x30贴吧,一个高质量的计算机技术交流平台.
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)