1

所以我遇到了一个问题,现在确定我做错了什么。我正在使用 python 2.4 和 subprocess 模块。这与我的 django 网站集成在一起。我有一个要求用户输入的表单,它将其放入文件中,然后使用文件所在的目录启动脚本。

如果我对字符串中的目录进行硬编码,它将正常工作,并输出 wlst 脚本,如果我不这样做,它将无法工作并且只是连接并认为它已完成。

仍然没有任何信息。至于为什么。该脚本可以在正常的命令行中正常工作,甚至可以在正常的 python 代码中工作。我唯一能说的是变量。

代码:

if form.is_valid():
                        env = form.cleaned_data['env']
                        user = form.cleaned_data['user']
                        group = form.cleaned_data['group']
                        role = form.cleaned_data['role']

                        id = ''.join(random.choice(string.ascii_uppercase + string.digits) for x in range(6))

                        root = "/opt/tools/Mapper/output/webui/%s" % (id)

                        if not os.path.exists(root):
                                os.makedirs(root)

                        output = open(root+"/mapping.out", 'w')

                        if (user):
                                user_stg = "User:"+user+":"
                                password = User.objects.filter(user__contains=user).values('password')

                                password_f = open(root+"/passwords.out", 'w')

                                password_out = "%s:%s" % (user, password[0]['password'].encode('ascii'))

                                password_f.write(password_out)
                        if (group):
                                grp_stg = "GroupName:"+group+":"
                        if(role):
                                role_stg = "RoleName:"+role

                        out_stg = user_stg+grp_stg+role_stg

                        output.write(out_stg+"\n")

                        command = "/opt/tools/Mapper/bin/wlst /opt/tools/Mapper/bin/creator -e ldap.dev -s pacdcespopsa1:7001 -o /opt/tools/Mapper/output/webui/JBHSMN"

                        args = shlex.split(command)

                        print args

                        resp = HttpResponse(command_output(args));

def command_output(args):
    import subprocess
    return subprocess.Popen(args, stdout=subprocess.PIPE, stderr=subprocess.PIPE).communicate()[0]

这段代码和变量驱动的唯一区别是我有

command = "/opt/tools/Mapper/bin/wlst /opt/tools/Mapper/bin/creator -e ldap.dev -s pacdcespopsa1:7001 -o %s" % (root)
4

0 回答 0