Ir para conteúdo

Arquivado

Este tópico foi arquivado e está fechado para novas respostas.

marlaaragao

Como setar timezone por cliente, e NÃO para aplicação inteira

Recommended Posts

Boa tarde,

 

Estou trabalhando em um sistema e ele tem uma tabela que seta algumas configurações de usuário. Uma dessas configurações é timezone. Mas como mudar as datas mostradas para cada usuário de acordo com a timezone escolhida por ele? Isso é possível?

 

Creio que não é possível fazer isso utilizando date_default_timezone_set, pois ela vai setar a timezone para aplicação inteira. Gostaria de saber se existe um jeito de antes de mostrar determinada data, ela possa ser modificada para a timezone do cliente e somente depois mostrada na tela.

 

Obrigada!

Compartilhar este post


Link para o post
Compartilhar em outros sites

date_default_timezone_set() vai mudar o timezone apenas para o usuário que está vendo aquela página

Se outro usuário acessar, cada um poderá ver a página em seu próprio timezone. Um não afeta o outro

 

Só vai afetar a aplicação toda (na verdade o PHP todo) se você modificar no php.ini. Se usar a função date_default_timezone_set(), a alteração ocorre apenas na requisição corrente

Compartilhar este post


Link para o post
Compartilhar em outros sites

date_default_timezone_set() vai mudar o timezone apenas para o usuário que está vendo aquela página

Se outro usuário acessar, cada um poderá ver a página em seu próprio timezone. Um não afeta o outro

 

Só vai afetar a aplicação toda (na verdade o PHP todo) se você modificar no php.ini. Se usar a função date_default_timezone_set(), a alteração ocorre apenas na requisição corrente

 

Olá Beraldo!

 

Obrigada pela resposta... Mas eu não estou conseguindo fazer funcionar. No arquivo php.ini a timezone não está setada.. Até aí tudo bem. Mas se eu não seto ela lá, ao rodar a aplicação aparece um warning dizendo:

 

"Message: date(): It is not safe to rely on the system's timezone settings. You are *required* to use the date.timezone setting or the date_default_timezone_set() function. In case you used any of those methods and you are still getting this warning, you most likely misspelled the timezone identifier. We selected the timezone 'UTC' for now, but please set date.timezone to select your timezone."

 

Aí vi que para esses warnings não aparecerem, eu devo setar a timezone no index.php com a funcão date_default_timezone_set(). Mas ao setar no index, não importa onde eu coloque ela de novo, sempre vai pegar a timezone setada no index.php.

 

Se eu tiro do index.php (não tinha visto que estava setada lá anteriormente, só q não tava no php.ini) funciona como você disse.

 

Essa pergunta talvez seja muito burra, mas é um problema simples que está me dando uma dor de cabeça. Poderia me ajudar de novo?

 

Muito obrigada!

Compartilhar este post


Link para o post
Compartilhar em outros sites

Verifique se está, de fato, chamando date_default_timezone_set no lugar correto (antes de date() ou outra função similar)

 

É possível mudar o timezone durante a execução. Veja:

 

 

<?php
$time = time();
 
date_default_timezone_set( 'America/Sao_Paulo' );
var_dump( date( 'd/m/Y H:i:s' ) );
 
date_default_timezone_set( 'America/New_York' );
var_dump( date( 'd/m/Y H:i:s' ) );

 

Saída

 

string '04/08/2015 15:27:40' (length=19)
string '04/08/2015 14:27:40' (length=19)

Compartilhar este post


Link para o post
Compartilhar em outros sites

 

Verifique se está, de fato, chamando date_default_timezone_set no lugar correto (antes de date() ou outra função similar)

 

É possível mudar o timezone durante a execução. Veja:

<?php
$time = time();
 
date_default_timezone_set( 'America/Sao_Paulo' );
var_dump( date( 'd/m/Y H:i:s' ) );
 
date_default_timezone_set( 'America/New_York' );
var_dump( date( 'd/m/Y H:i:s' ) );

Saída

string '04/08/2015 15:27:40' (length=19)
string '04/08/2015 14:27:40' (length=19)

 

Noosssa, muito obrigada!

 

Que burrice, meu deus... era só o local no qual eu estava colocando a função date_default_timezone_set(..), e fiquei tanto tempo presa nisso... Muito obrigada mesmo, e desculpe o incômodo..

 

=]

Compartilhar este post


Link para o post
Compartilhar em outros sites

  • Conteúdo Similar

    • Por violin101
      Caros amigos, saudações.

      Por favor, me perdoa em recorrer a ajuda dos amigos, mas preciso entender uma processo que não estou conseguindo sucesso.

      Como mencionado no Título estou escrevendo um Sistema Web para Gerenciamento de Empresa.
       
      Minha dúvida, que preciso muito entender:
      - preciso agora escrever a Rotina para Emissão de NFe e essa parte não estou conseguindo.
       
      tenho assistido alguns vídeos e leituras, mas não estou conseguindo sucesso, já fiz toda as importações das LIB da NFePhp conforme orientação.

      Preciso de ajuda.

      Algum dos amigos tem conhecimento de algum passo-a-passo explicando a criação dessa rotina ?

      tenho visto alguns vídeos com LARAVEL, mas quando tento utilizar e converter para PHP+Codeiginter, dá uma fila de erros que não entendo, mesmo informando as lib necessárias.

      Alguns do amigo tem algum vídeo, leitura explicando essa parte ?

      Grato,

      Cesar.
    • Por violin101
      Caros amigos, saudações.

      Por favor, me perdoa em recorrer ao auxílio dos amigos, mas preciso entender e resolver um problema.
       
      Tenho uma Rotina que o usuário seleciona os produtos que deseja para requerer ao setor responsável.
       
      O usuário escolhe um produto qualquer e Clicla em um button para incluir a lista.

      O problema que estou enfrentando é que após escolher o produto e teclar ENTER o Sistema já salva no BD.
       
      Gostaria de criar uma Tecla de Atalho, para quando incluir/escolher o produto na lista, o usuário tecla como exemplo:
      ALT+A  para agregar a lista
      ALT+S para salvar a lista de itens desejados.

      Assim, quando teclar enter, o sistema não dispara o GRAVAR na Base de Dados.

      Grato,

      Cesar
       
       
       
    • Por violin101
      Caros amigos, saudações.

      Por favor, peço desculpa em recorrer a ajuda dos amigos referente uma dúvida.

      Tenho um Sistema que estou escrevendo em PHP + Codeigniter e a minha dúvida em Codeigniter é:
      Obs.: as tabela são em MySql

      => como faço para IMPORTAR o dado de uma Tabela para outra, as tabela são:
      ___________________Tabela de Pedido     =========== para ==========>    Tabela de Entrada de Lançamentos
      itens: codigoProduto | quantidade | valorUnitario  === importar===> itens: codigoProduto | quantidade | valorUnitario
       
      Estou tentando de várias formas, mas não estou conseguindo.

      Por favor, alguém pode me dar uma ajuda, explicação ou orientação.

      Grato,
       
      Cesar
       
    • Por violin101
      Caros amigos, saudações.
       
      Estou com uma pequena dúvida que não estou conseguindo resolver.

      Tenho 2 Tabelas, a 1ª.principal e a 2ª.secundária.

      Exemplo:
      Dados da 1ª Tabela - Peças e Equipamentos
      Dados da 2ª Tabela - Veículos.

      Seria isso:
      0010 - Pneu Aro 20
        [x] 001 - Corsa
        [_] 002 - Fusca
        [_] 003 - Palio
      Comentário:________________
       
      0100 - Óleo para Motor
         [x] 002 - Fusca
         [_] 003 - Palio
      Comentário:________________
       
      1030 - Lubrificante
         [_] 001 - Corsa
         [x] 003 - Palio
      Comentário:________________
       
      O meu problema está sendo quando preciso SALVAR/ATERAR o campo COMENTÁRIO, pois trata-se da 1ª.tabela.
       
      Gostaria salvar o COMENTÁRIO sem interferir nas seleção da 2ª. tabela.
       
      Grato,
       
      Cesar
       
       
       
       
       
    • Por Carcleo
      Estou começando no Laravel 11 e me deparei com um problema de belongsTo
       
      public function listOfClass(Request $request, StudentDisciplineClassroom $sdc) : ?string {         $all = $sdc::select('student')->with('studentRelation')->where('classroom',$request->classroom)->distinct('student')->get();     dd($all->toArray());     $students = [];     foreach ($all as $student) {             $students[] =$student;     }       return response()->json($students)->getContent();     } isso

      Em studentRelation temos na tabela StudentDisciplineClassroom com os campos

      id(chave primaria)
      ra (chave estrangera que referencia o campo academic_registration na tabela de students)

      e a tabela student tem os campos

      id (chave primária)
      academic_registration (que vai ser refeenciada na tabela StudentDisciplineClassroom

      Mas na hora de fazer
      $sdc::select('student')->with('studentRelation')->where('classroom',$request->classroom)->distinct('student')->get();
      O studentRelation retorna nulo

      Onde eu posso estar errando?
×

Informação importante

Ao usar o fórum, você concorda com nossos Termos e condições.