如何在C 中用程序执行指定的SQL脚本文件,实

如何在C 中用程序执行指定的SQL脚本文件,实,第1张

1、用cmd命令打开DOS命令行窗口

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贴吧,一个高质量的计算机技术交流平台.


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/yw/12562186.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2025-08-26
下一篇2025-08-26

发表评论

登录后才能评论

评论列表(0条)

    保存