Jump to content
Nioshi

[Resolvido] $_post recebe variável nula do c#

Recommended Posts

Boa tarde, estou enfrentando um problema em meu código, eu tenho um código em c# que fica ouvindo a porta 12934, quando recebe requisição ele envia um post ao meu arquivo php, o problema está que o $_POST recebe valor nulo por algum motivo que ainda não descobri.

 

código no c#:

string URLreceber = "http://localhost/pweb/modulose";
string URLRetornoimg = "http://localhost/pweb/modulos";
string URLRetornocam = "http://localhost/pweb/moduloscaminho";

using (var cliente = new WebClient())
                {
                    NameValueCollection modulose = new NameValueCollection();
                    modulose["folha"] = folha;
                    modulose["informe"] = informe;
                    modulose["cartao"] = cartao;
                    Console.WriteLine(modulose["folha"]);
                    Console.ReadKey();

                    resultimg = cliente.UploadValues(URLRetornoimg, modulose);
                    retorno = Encoding.UTF8.GetString(resultimg);
                    Console.WriteLine(retorno);
                    Console.ReadKey();
                }

código em php:

$app->post('/modulos', function (Request $request) use ($app) {
	$modFolha = '';
	$modInforme = '';
	$modCartao = '';
		if(isset($_POST['folha'])){
			$modFolha = $_POST['folha'];	
		}
		if(isset($_POST['informe'])){
			$modFolha = $_POST['informe'];	
		}
		if(isset($_POST['cartao'])){
			$modFolha = $_POST['cartao'];	
		}

		if($modFolha == 'sim'){
			$modFolha = 'sim';
		}else{
			 $modFolha = 'nao';
		}
		if($modInforme == 'sim'){
			$modInforme = 'sim';
		}else{
			 $modInforme = 'nao';
		}
		if($modCartao == 'sim'){
			$modCartao = 'sim';
		}else{
			$modCartao = 'nao';
		}

	if($modFolha == 'sim'){
		$modulosImagem['folha'] = './images/holerite.png';
	}else{
		$modulosImagem['folha'] = './images/holeriteDesabilitado.png';
	}
	if($modInforme == 'sim'){
		$modulosImagem['informe'] = './images/informeVerde.png';
	}else{
		$modulosImagem['informe'] = './images/informeDesabilitado.png';
	}
	if($modCartao == 'sim'){
		$modulosImagem['cartao'] = './images/cartao.png';
	}else{
		$modulosImagem['cartao'] = './images/cartaoDesabilitado.png';
	}
	if(file_exists("../app/config/global.php")){
		return new Response(json_encode($modulosImagem), 201);
	}
	else{
		return new Response("Arquivo global não existe", 500);
	}
});

Código em .js

  // post para a rota que retorna os dados
  $http.post('./modulos', data, setting)
  .success(function (data, status, headers, setting){
    $scope.folha = angular.fromJson(data).folha;
	  $scope.informe = angular.fromJson(data).informe;
	  $scope.cartao = angular.fromJson(data).cartao;
  })
  .error(function (data, status, header, setting){
    $scope.ResponseDetails = "Erro: " + data ;
  });
  
  var setting = {
    headers : {
      'Content-Type': 'application/x-www-form-urlencoded;charset=utf-8;'
    }
  }

com as linhas:

ini_set('display_errors', true);
error_reporting(E_ALL);

ele retorna:

http://prntscr.com/lhhpdu

 

e sem as linhas ele retorna NULL, alguém sabe dizer no que estou errando?

 

retorno no c#:

http://prntscr.com/lhhqba

 

variáveis pegas:

http://prntscr.com/lhhqr6

Share this post


Link to post
Share on other sites

Acredito que o dado esteja sendo recebido de forma bruta pelo APACHE/PHP, mas a variável $_POST não é populada.

 

Veja se com o seguinte código você não recupera o valor enviado:

$postdata = file_get_contents("php://input");
var_dump($postdata);

De qualquer forma, $_POST somente será populada se os dados forem:

  • application/x-www-form-urlencoded;
  • multipart/form-data-encoded.

No mais, ficam no input stream acima mencionado.

http://php.net/manual/en/wrappers.php.php#wrappers.php.input

Share this post


Link to post
Share on other sites

opa Gabriel, obrigado pelo retorno, eu coloquei o código que você sugeriu e retornou isso no navegador.

http://prntscr.com/lhi2nc

 

o que eu estou achando estranho, é que eu já fiz um código parecido e o $_POST pegou a variável vinda do c# normalmente:

 

código em c#: 

http://prntscr.com/lhi39n

código em php:

http://prntscr.com/lhi3wa

 

por isso não estou achando o motivo dele receber null

Share this post


Link to post
Share on other sites

Evite trazer os prints, traga os códigos/textos mesmo. Tem as opções de adicionar código e citações aqui no editor.

 

Como é possível visualizar no primeiro link, ele está no input stream.

Share this post


Link to post
Share on other sites
3 minutos atrás, Gabriel Heming disse:

Evite trazer os prints, traga os códigos/textos mesmo. Tem as opções de adicionar código e citações aqui no editor.

 

Como é possível visualizar no primeiro link, ele está no input stream.

ok, desculpe pelos prints.

 

isso quer dizer que a variável não está nula, e meu problema é outro?

Share this post


Link to post
Share on other sites
14 minutos atrás, Nioshi disse:

ok, desculpe pelos prints.

 

isso quer dizer que a variável não está nula, e meu problema é outro?

Ela está nula. Isso apenas quer dizer que os dados estão chegando no PHP.

 

É bem provável que o seu problema esteja aqui:

$http.post('./modulos', data, setting)

Deve validar se a variável data está no formato adequado para enviar ao PHP.

Share this post


Link to post
Share on other sites

descobri que seu setar manualmente desta forma a variável antes do if:

$modFolha = 'sim';

 

ele entra no if normalmente e envia a imagem correta ao .js.

Share this post


Link to post
Share on other sites
16 minutos atrás, Nioshi disse:

descobri que seu setar manualmente desta forma a variável antes do if

Sabe que isso não faz o menor sentido?

 

Se for analisar melhor seu código, o código abaixo não faz praticamente nenhum sentido:

$modFolha = '';
$modInforme = '';
$modCartao = '';
    if(isset($_POST['folha'])){
        $modFolha = $_POST['folha'];	
    }
    if(isset($_POST['informe'])){
        $modFolha = $_POST['informe'];	
    }
    if(isset($_POST['cartao'])){
        $modFolha = $_POST['cartao'];	
    }

    if($modFolha == 'sim'){
        $modFolha = 'sim';
    }else{
         $modFolha = 'nao';
    }
    if($modInforme == 'sim'){
        $modInforme = 'sim';
    }else{
         $modInforme = 'nao';
    }
    if($modCartao == 'sim'){
        $modCartao = 'sim';
    }else{
        $modCartao = 'nao';
    }

if($modFolha == 'sim'){
    $modulosImagem['folha'] = './images/holerite.png';
}else{
    $modulosImagem['folha'] = './images/holeriteDesabilitado.png';
}
if($modInforme == 'sim'){
    $modulosImagem['informe'] = './images/informeVerde.png';
}else{
    $modulosImagem['informe'] = './images/informeDesabilitado.png';
}
if($modCartao == 'sim'){
    $modulosImagem['cartao'] = './images/cartao.png';
}else{
    $modulosImagem['cartao'] = './images/cartaoDesabilitado.png';
}

Algumas variáveis (modInforme e $modCartao) nunca serão preenchidas. Uma delas ($modFolha) é preenchida para depois ser validada e preenchida com o mesmo valor.

 

Sobre o seu problema original, o que você deve fazer é validar a entrada dos dados no javascript, verificar se estão sendo enviados corretamente. Caso não resolver, pegue diretamente os valores do input stream php://input.

Share this post


Link to post
Share on other sites

boa tarde, apesar de eu ter começado meu programa c# do zero, eu só queria deixar registrado aqui que eu resolvi o meu problema com webserver no c#, e cURL no lado do PHP, no qual o c# envia minha informação para minha url "http://localhost:12934/mod/" e o cURL pega a informação dessa URL.

Abraço e obrigado pela ajuda.

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now

  • Similar Content

    • By WitchMad
      Ooi gente!
      Seguinte, estou desenvolvendo uma plataforma para advogados. Nela será consultado processos a partir do web service do PJE.
      No site do PJE me recomendou utilizar o NuSoap para consultar o web service e foi o que eu fiz.
      Segue o código da consulta
      <?php require_once 'nusoap/lib/nusoap.php'; /* Parâmetros Requisitados */ // idConsultante // senhaConsultante // numeroProcesso /* Objetos de Resposta sucesso bollean Indica se houve sucesso na consulta do processo. mensagem string Mensagem informando que o processo foi consultado com sucesso. recibo xs:base64Binary Comprovante do protocolo do processo, que contém os dados básicos do processo. */ $wsdl = "https://www.tjpe.jus.br/pje/intercomunicacao?wsdl"; $client = new nusoap_client($wsdl, 'wsdl'); if($client->getError()){ echo "Erro no construtor" . $client->getError(); exit(); } $result = $client->call('consultarProcesso', array('idConsultante'=>'CPF do Consultante', 'senhaConsultante'=>'Senha do Consultante', 'numeroProcesso'=>'Número do Processo')); echo $result['sucesso']; ?> Acontece que a página fica em branco, sem nenhum tipo de mensagem.
      Se possível gostaria de dicas se há algum erro no código, ou alguma outra ferramenta para consultar web service
    • By Leonardo Ortega
      Prezados, bom dia.
      sou novo por aqui, e me deparei com esta situação:
      estou desenvolvendo um projeto e tudo começou quando apenas mudei o banco de dados que estava conectado. Ou seja, se eu me conecto ao baco de dados anterior, volta todo código html, porém, se conecto ao banco de dados atual as divs desaparecem. 
       
      obs: Isso tb acontece quando eu desativo o php tudo volta como a imagem 1 e se eu ativo fica como a imagem2.
       
      quem pode me ajudar.. desde já muito obrigado.  


    • By Richard.Ribeiro
      Fala Pessoal.. Bom dia.. uma ajuda por favor.
      não sei se e a melhor opção mais, gostaria de criar um id sequencial id="material"
      para resolver seguinte problema.. com javascript eu crio select com dados selecionados anteriormente, e crio mais opção no caso de haver mais pedido, porém toda vez que preciso troca a categoria o PRIMEIRO selecte que já possui um item e resetado. como posso resolver isso O PRIMIEIRO SELECT NÃO MUDAR. uma vez que á possui value selected
       
      segue todo código:

        <div id="box" >
        <form id="cadastro"  method="post">
          <?php
            if(isset($_POST['acao'])){
              $ide = $_POST['ide'];
              $data = $_POST['data_pedido'];
              $username=$_SESSION['username'];
              $justificativa = $_POST['justificativa'];
              $id_tipo_material = $_POST['material'];
              $qnt_solicitada = $_POST['qnt_solicitada'];

              //cadastrar no banco de dados!
                  $gravar = new Painel();
                  $id_gsm = $gravar->cadastrarGsm($data,$username,$justificativa,$ide);
                  $gravar->cadastrarItem($id_gsm,$id_tipo_material,$qnt_solicitada);
                  Painel::alert('sucesso','Pedido realizado com sucesso!');
                  }
                  $ConsultaIde = ConexaoBD::conectar()->prepare("SELECT  vsat_gilat, 'IDE: '||vsat_gilat|| ', Situação:'|| situacao|| ', Localidade:'||localidade|| ', Logradouro: '||logradouro as local
        FROM vsat WHERE vsat_gilat != '' AND situacao = 'Ativo'");
                  $ConsultaIde->execute();
                  $ConsultaIde = $ConsultaIde->fetchAll();
        ?>
        <div >
        <div class="form-group">
              <label>Selecione uma IDE</label>
              <select class="ide" name="ide" id="ide" required>
                <option disabled selected>-- Selecione IDE --  </option>
                  <?php
                  foreach ($ConsultaIde as $key => $value) {
                    ?>
                    <option value="<?php echo $value['vsat_gilat'];?>">
                      <?php echo $value['local'];?>

                </option>
              <?php }?>
              </select>

              <label>Data da Solicitação do Material :</label>
              <input type="text"value="<?php   echo date('d/m/Y');    ?>"  name="data_pedido" readonly >
        </div><!--form-group-->
            <div class="form-group">
              <label>Justificativa do pedido:</label>
              <textarea  rows="8" cols="80" name="justificativa" required></textarea>
        </div><!--form-group-->

        <div class="form-group">
              <label>Selecione Sistema:</label>
              <select name="id_categoria" id="id_categoria">
              <option selected disabled> --- Selecione o Sistema ---</option>
            <?php
        $consulta= ConexaoBD::conectar()->prepare("SELECT id_sistema, descricaos FROM public.cadastrar_sistema");
        $consulta->execute();
        while($row_cat_post = $consulta->fetch(PDO::FETCH_ASSOC) ) {
        echo '<option value="'.$row_cat_post['id_sistema'].'">'.$row_cat_post['descricaos'].'</option>';
              }
        ?>
          </select>
        </div><!--form-group-->
        <div class="form-group">
          <label>Selecione Padrão:</label>
          <span class="carregando">Aguarde, carregando...</span>
          <select name="id_sub_categoria" id="id_sub_categoria" >
            <option value="">--- Selecione o Padrão ---</option>
          </select>
        </div><!--form-group-select-->

        </div>
        <div class="pedido">
          <div class="remover">
          <label>Selecione Material:</label>
          <span class="carregando">Aguarde, carregando...</span>
          <select name="material[]" id="material">
            <option value="">--- Selecionte o Material ---</option>
          </select>
          <input type="text" id="quantidade" name="qnt_solicitada[]" placeholder="Digite a Quantidade" >
      <button type="button" name="button" class="removedor">Remover Item</button>
      </div>
      </div>
      </div>
        <button type="button" name="button" class="clonador">Novo Item</button>
        <input type="submit" name="acao" value="Cadastrar!">
        </form>
       
       
       
       
       
       
       
        <script type="text/javascript" src="https://www.google.com/jsapi"></script>
                <script type="text/javascript">
                  google.load("jquery", "1.4.2");
                </script>
      <script  src="<?php echo INCLUDE_PATH_PAINEL ?>js/jquery-3.4.1.min.js"></script>
      <script type="text/javascript">
        $(function(){
          $('#id_categoria').change(function(){
            if( $(this).val() ) {
              $('#id_sub_categoria').hide();
              $('.carregando').show();
              $.get('sub_categorias_post?search=',{id_categoria: $(this).val(), ajax: 'true'}, function(j){
                html = $.parseHTML(j);
                j=JSON.parse(html[16].textContent.trim());
                var options = '<option value="">Escolha Subcategoria</option>';
                for (var i = 0; i < j.length; i++) {
                  options += '<option value="' + j.id + '">' + j.nome_sub_categoria + '</option>';
                }
                $('#id_sub_categoria').html(options).show();
                $('.carregando').hide();
              });
            } else {
              $('#id_sub_categoria').html('<option value="">– Escolha Subcategoria –</option>');
            }
          });
        });
        $(function(){
          $('#id_sub_categoria').change(function(){
            if( $(this).val() ) {
              $('#material').hide();
              $('.carregando').show();
              $.get('sub_categorias_post2?search=',{id_sub_categoria: $(this).val(), ajax: 'true'}, function(j){
                html = $.parseHTML(j);
                console.log(html);
                j=JSON.parse(html[16].textContent.trim());
                var options = '<option value="">Escolha Subcategoria</option>';
                for (var i = 0; i < j.length; i++) {
                  options += '<option value="' + j.id + '">' + j.nome_sub_categoria + '</option>';
                }
                $('#material').html(options).show();
                $('.carregando').hide();
              });
            } else {
              $('#id_sub_categoria2').html('<option value="">– Escolha Subcategoria –</option>');
            }
          });
        });
        </script>
        <script>
        $(document).ready(function(){
       
              $(document).on('click', '.clonador', function(e){
                var elm_html = $('.pedido').html();
                var counter = 0;  //faz uma cópia dos elementos a serem clonados.
                  e.preventDefault();
                  var elementos = elm_html.replace(/\[[0\]]\]/g, '['+ counter +']');  //substitui o valor dos index e incrementa++
                  counter++;
                  $('#cadastro').append(elementos);  //exibe o clone.
              });
          });

          $(document).on('click', '.removedor', function (event) {
            event.preventDefault();
            $(this).parents('.remover').remove(); // navega até o pai com a classe pedido e remove ele inteiro
          });
        </script>
       
        <?php
        die();
        ?>
      </div><!--box-content-->
    • By djwagnersp
      Bom dia amigos, tudo bem? estou com uma duvida se alguém puder me ajudar agradeço desde já.
       
      tenha a seguinte condição:
      //array dos produtos $prod = 'agua'; $prod = 'refri'; $prod = 'cerveja'; //array das quantidades $qtd = '3'; $qtd = '2'; $qtd = '6'; Gostaria de fazer um loop o for ou foreach que imprimisse o $prod a quantidade de vezes do $qtd
      como seria possível realizar isso?
    • By emmanuelsiqueira30
      Estou tentando inserir os valores de uma matrícula e gerar já as parcelas das mensalidades.
      Agradeço toda ajuda possível.
       
      cadMatriculaModel.php
      <?php include("../Controller/conexao.php"); include("../Controller/util.php"); header('Content-Type: text/html; charset=utf-8'); $id_aluno = $_POST['id_aluno']; $id_curso = $_POST['id_curso']; $data_matricula = date("Y-m-d"); $codunico_matricula = bin2hex(random_bytes(8)); $tipo_pag_matricula = $_POST['tipo_pag_matricula']; $dia_venc_matricula = $_POST['dia_venc_matricula']; $n_parc_matricula = $_POST['n_parc_matricula']; $sql_valor_curso = "SELECT * FROM curso WHERE id_curso = $id_curso"; $result_valor_curso = mysqli_query($con,$sql_valor_curso); $row_valor_curso = mysqli_fetch_assoc($result_valor_curso); $valor_curso = $row_valor_curso['valor_curso']; $dt_curso_ini = $row_valor_curso['data_inicio_curso']; $dt_curso_fim = $row_valor_curso['data_fim_curso']; $dif = strtotime($dt_curso_fim) - strtotime($dt_curso_ini); $periodo_curso_meses = floor($dif / (60 * 60 * 24 * 30)); $valor_parc = intval($valor_curso) / $periodo_curso_meses; $sqlmatricula = "INSERT INTO matricula (id_aluno,id_curso,data_matricula,codunico_matricula,tipo_pag_matricula,dia_venc_matricula,n_parc_matricula) VALUES ('$id_aluno','$id_curso','$data_matricula','$codunico_matricula','$tipo_pag_matricula','$dia_venc_matricula','$n_parc_matricula')"; $resultmatricula = mysqli_query($con,$sqlmatricula); $ultimamatricula = mysqli_insert_id($con); if($resultmatricula == true){ //echo "<script>alert('Matrícula realizada com sucesso.');</script>"; $x = 1; while($x >= $n_parc_matricula){ //for ($x = 0; $x == $n_parc_matricula; $x++) { /* $dia = date("d"); $mes = date("m"); $ano = date("Y"); $dt_venc_pr = date("Y/m/d",strtotime("+".$x." month",mktime(0, 0, 0,$dia,$mes,$ano))); echo $dt_venc_pr; */ $sqlpr = "INSERT INTO parcelareceber (id_matricula,id_aluno,id_curso,valor_parc_pr,dt_pag_pr) VALUES ('$ultimamatricula','$id_aluno','$id_curso','$valor_parc','$data_matricula')"; $resultpr = mysqli_query($con,$sqlpr); echo $sqlpr; if($resultpr == true){ echo "<script>alert('Parcelas geradas com sucesso.');</script>"; }else { echo "<script>alert('Erro na inserção das parcelas.');</script>"; echo $resultpr; } } echo $x; echo $n_parc_matricula; }else{ } cadMatriculaView.php
      <!DOCTYPE html> <html> <title>Matrícula do aluno</title> <head> <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.6.1/jquery.min.js"></script> </head> <body> <?php include 'menuView.php'; ?></br></br> <?php ini_set( 'default_charset', 'UTF-8' ); ini_set( 'mbstring.http_output', 'UTF-8' ); ini_set( 'mbstring.internal_encoding', 'UTF-8' ); header("Content-Type: text/html; charset=UTF-8",true); ?> <font face="verdana" size="4"> <form action="../Model/cadMatriculaModel.php" method="POST"> <fieldset> <legend>CONSULTA DE ALUNO</legend> <label for="proprietario_id_prop">Digite o CPF do aluno: </label> <input type="text" class="form-control" name="textbox" id="textbox" placeholder="Digite CPF do aluno"></br> ALUNO: <select class="form-control" name="id_aluno" id="select" style="width: 400px"> <?php include ("../Controller/conexao.php"); $query = "SELECT * FROM aluno"; $consulta = mysqli_query($con,$query); while ($dados = mysqli_fetch_assoc($consulta)) { ?> <option value="<?php echo $dados['idaluno']; ?>"><?php echo $dados['cpfaluno'] . " - " . $dados['nomealuno']; ?></option> <?php } ?> </select></br> </fieldset> <fieldset> <legend>ESCOLHA DO CURSO</legend> CURSO: <select class="form-control" name="id_curso" id="select"> <?php include ("../Controller/conexao.php"); $query = "SELECT * FROM curso"; $consulta = mysqli_query($con,$query); while ($dados = mysqli_fetch_assoc($consulta)) { ?> <option value="<?php echo $dados['id_curso']; ?>"><?php echo $dados['nome_curso'] . " - " . $dados['turno_curso']; ?></option> <?php } ?> </select></br> </fieldset> TIPO DE PAGAMENTO: <select name="tipo_pag_matricula"> <option value="1">A PRAZO</option> </select></br> DIA DO VENCIMENTO: <input type="text" name="dia_venc_matricula" maxlength="2"> NÚMERO DE PARCELAS: <input type="text" name="n_parc_matricula" maxlength="2"><br> <span style="color: red; font-size: 8pt">* Campos obrigatórios.</span></br> <button type="submit" name="btninserir">INSERIR MATRÍCULA</button> </form> </font> <script> jQuery.fn.filterByText = function(textbox, selectSingleMatch) { return this.each(function() { var select = this; var options = []; $(select).find('option').each(function() { options.push({value: $(this).val(), text: $(this).text()}); }); $(select).data('options', options); $(textbox).bind('change keyup', function() { var options = $(select).empty().data('options'); var search = $(this).val().trim(); var regex = new RegExp(search,"gi"); $.each(options, function(i) { var option = options[i]; if(option.text.match(regex) !== null) { $(select).append( $('<option>').text(option.text).val(option.value) ); } }); if (selectSingleMatch === true && $(select).children().length === 1) { $(select).children().get(0).selected = true; } }); }); }; $(function() { $('#select').filterByText($('#textbox'), false); $("select option").click(function(){ alert(1); }); }); </script> </body> </html> E também est[a dando esse erro Notice: Undefined index: dia_venc_matricula in C:\xampp\htdocs\curso\Model\cadMatriculaModel.php on line 15 mas já verifiquei a variávewl e está correta.
×

Important Information

Ao usar o fórum, você concorda com nossos Terms of Use.