Solucionado (ver solução)
Solucionado
(ver solução)
18
respostas

Erro no log para " GET http://localhost:8180/angularTests/%7B%7Burl%7D%7D 404 (Not Found)"

Estou tentando de varias maneiras desvendar o erro : GET http://localhost:8180/angularTests/%7B%7Burl%7D%7D 404 (Not Found) Que aparece no log do Chrome.....

Criei um projeto java com jboss 6.1 e rest para enviar a resposta conforme link: https://github.com/leonardocregis/restforjboss61

Não usei a função: $locationProvider.html5Mode(true); porque queria focar no angular, não usei o servidor que vc disponibilizou porque a minha empresa não permite a instalação de nada ....

O que já observei sobre ele: - não ocorre se não tiver nenhum valor - não importa se remover itens da lista dbfiles.json , sempre que existe um item pelo menos dá o erro.

Qualquer informação adicional , so perguntar....

18 respostas

Bom, parece que sua url está sendo gerada de forma errada.. Eu tentaria olhar isso.. Outra coisa que você precisa garantir que todos endpoints estejam iguais aos do projeto disponibilizado, para que o cliente funcione corretamente.

A tela abre e exibe todas as imagens com os seus títulos, efetivamente é como se não houvesse erro algum....

Porém o log mostra isso. Me incomoda algo assim, gostaria de conseguir dicas para isolar... mas em termos de código parece algo interno do framework talvez.

Com relação aos Endpoints , eles respondem a lista de objetos como necessário, do contrário não teríamos nada exibido...

Opa Leonardo, acho que entendi errado sua dúvida, perdão. Só agora entendi que tem alguma requisição a mais sendo feita.. é isso? Olhando seu código ainda não identifiquei. Talvez Flavio ou outra pessoa tenha uma vista mais apurada.

essa questao da "requisicao à mais" é que nao encontrei de forma alguma........ mas parece ter para uma url q de fato nao existe no servidor.

Vou fazer uma versao sem jboss rodando para ver como fica.. e dou um retorno

desculpem amigos, achei que tinha colocado o ultimo update lá no github, agora está com as atualizações para reproduzir o erro.. ..

Oi Regis!

Pelo o que eu entendi, você criou seu próprio backend em Java, foi isso? Se for, talvez o ideal seja você postar sua dúvida no fórum de REST, por exemplo. Mas primeiro vamos ver se é algo do Angular. Angular é direto se a URL não existir você recebe essa mensagem.

Uma dica é você consumir sua API com jQuery e ver se funciona, se não funcionar. você precisa rever seu backend.

Outra coisa, você até colocou o projeto no Github mas não diz o que deve ser feito para replicar o problema, nem mesmo o código de qual controller disparado a requisição. Ai complicada ajudar né.

Olhando seu código, acho que é esse controller, confere para mim:

angular.module('myapp').controller('ImageCtr',['$scope','$http',function($scope,$http){

        $scope.fotos = [];
        $scope.filtro = '';

        $http.get('rest/posts')
            .success(function(retorno){
                $scope.fotos = retorno;
            })
            .error(function(error){
                console.log(error);
            });

}]);

Se for, veja que a URL rest/posts não esta sendo encontrada pelo Angular. O que você pode tentar é fazer /rest/posts. Veja que há uma barra antes do endereço.

Aguardo seu retorno.

Peco desculpas pela falta de mais detalhamento na explicação, estou arrumando um tempo para detalhar mais.

Porém, garanto que o problema não está no lado do servidor, quando falamos no quesito dele responder à requisicao da url "rest/posts".

Adianto que o mesmo retorna o conteúdo exatamente igual ao que está no "dbfiles.json". (se quiser copio e colo aqui o que ele retorna)

Então , assumindo que ao chamar a url "rest/posts", ele retorna o conteúdo do "dbfiles.json" o resto é só o trabalho do Angular.

Observo aqui para agregar, que já eliminei umas fotos do arquivo para ver se o erro ocorre, noto que é logado apenas 1 vez desde que seja mais de 1 foto. Se removo todas e deixo somente o "[]" nada é trazido de erro no log.

Fiz uma alteração e o erro ocorreu novamente.

Agora não tem rest na historia para levar a culpa....

No javascript ImageCtr.js, vc irá substituir pelo código abaixo:

angular.module('myapp').controller('ImageCtr',['$scope','$http',function($scope,$http){

        $scope.fotos = [{"url":"",
            "titulo":"Lobo",
            "grupo":"4",
            "id":"E18e8augUd5ixcde"
            }];
        $scope.filtro = '';


}]);

Atenção que coloquei o código entre aspas "" não copiar as aspas..

Regis, pelo o que eu entendi você colou um dado fixo no $scope para ver se ele é exibido . Certo? Nesse caso você não esta mais usando $http.get, perfeito? E nada é exibido? Se for, o problema agora é outro, do Angular que cedo ou tarde você se depararia.

E quando você executa esse código, o que acontece? Agora eu acho que há múltiplos problemas. Por isso é importante eu fazer algumas perguntas e que você responda uma a uma.

As imagens são exibidas? Qual mensagem é exibida no console? Como eu disse, como você não esta mais buscando os dados do servidor (erro na sua API) e agora fornece os dados diretamente e não exibiu nada, esse sim é problema no Angular. Dai preciso analisar seu código.

Onde esta a mensagem do console do Chrome, usando os dados fixos como no seu exemplo?

Aliás, tem como fazer um exemplo com duas fotos apenas no array? Eu não tenho como rodar sua aplicação. Eu quero descartar qualquer dados inválido no seu arquivo.

Você falou do erro, mas o que acontece em sua aplicação? Ela funciona, mas a mensagem é exibida no console, só isso? É isso que você esta estranhando?

Eu não tenho como subir sua aplicação agora.

Pelo o que eu entendi você colou um dado fixo no $scope para ver se ele é exibido . Certo?

  • sim Nesse caso você não esta mais usando $http.get, perfeito?
  • sim

E quando você executa esse código, o que acontece?

  • a tela é exibida normalmente e no console(e aba network) é informado o erro

As imagens são exibidas?

  • sim, todas que eu colocar inclusive com texto delas tmb

Qual mensagem é exibida no console?

  • aquela que coloquei no titulo

Onde esta a mensagem do console do Chrome, usando os dados fixos como no seu exemplo?

  • Na aba console, e na aba network como um recurso que não conseguiu obter

Aliás, tem como fazer um exemplo com duas fotos apenas no array?

  • fiz com 0,1, 2 , 3 , 4, 5. O erro so aparece quando coloco de 1 até 5 imagens, ele não repete pelo número de imagens.

O que acontece na aplicação ?

  • Nada , ela se comporta normalmente (aparentemente)

A mensagen é exibida no console só isso ?

  • Sim , a mensagem só aparece no console.

É isso que você esta estranhando ?

  • Sim , só isso,. À princípio as vezes pequenos erros causam grandes problemas no futuro, ou não(hehe)..

Altere o template da sua diretiva e nela use ng-src no lugar de src.

Você vai pegar a diretiva da sua imagem e onde esta src vai trocar para ng-src. Faça o teste e veja se a mensagem ainda é exibida no console.

descobri a causa do problema... Particularmente é até um ponto que ia perguntar porque não foi levantado.

O uso da diretiva ng-src, que pós processa a carga de referencias de imagem...

Acabei vendo na mesma hora, nem me liguei.

Particularmente, esse erro me fez levantar uma dúvida, como você "desvenda" um erro desses? Baixa o fonte do angular e "debuga" ?

solução!

Nesse caso, quando você disse que não havia erro na aplicação e apenas essas mensagem.. quando olhei a URL da mensagem de erro..vi que era uma URL não interpolada pelo angular (no seu report original fui induzido a entender que era problema em $http.get). Isso acontece. porque o browser tem uma política agressiva de carregamento de imagem e baixa a imagem antes do Angular entrar em ação. Sendo assim... ele da essas mensagens, mas assim que o Angular toma o controle ele interpola a imagem e resolve o problema. Quando usamos ng-src, estamos enganando o browser. Ele não entende que tem que baixar a imagem, daí quando angular toma o controle.. ele altera o ng-src para src e a imagem é baixada. Evitando assim o erro.

Fico contente de ter esclarecido esse problema.

Sucesso e bom estudo.