tjah..
Als je deze niet hebt klopt je db model niet.
Reg. datum: 22 januari 2004
Edit: dacht dat je uploads zonder extensie binnenkreeg.
Je wilt de extensie forceren o.i.d? (Dus altijd .jpg en niet .JPG of .jpeg?)
Icelus wijzigde dit bericht 24-07-2008 11:50 (24%)
Whereas Europeans generally pronounce my name the right way ('Nick-louse Veert'), Americans invariably mangle it into 'Nickel's Worth.' This is to say that Europeans call me by name, but Americans call me by value - Niklaus Wirth
Dit is niet mogelijk. Gaat om een ledenbestand met ruim 2000 records, plaatjes zijn pasfoto's en komen random binnen. Echt een kloteklus om die 2000 records met de hand nog eens na te lopen.quote:voeg een extra kolom toe, met danwel de extensie danwel de content-type ?
Als je deze niet hebt klopt je db model niet.
Nee, ik wil dat php in de folder kijkt, of het bestand met een bepaalde naam bestaat. Maar php weet de extensie niet, dus die zal meerdere bestanden moeten proberen.quote:Je wilt de extensie forceren o.i.d? (Dus altijd .jpg en niet .JPG of .jpeg?)
tjah..
[edit]ah ik heb het nogmaals gelezen en begrijp het nu beter. Je wilt dus door de map loopen om te kijken of de betreffende bestandsnaam bestaat. Tja, niet echt handig (ook niet voor de performance), maar een loopje d.m.v. een array o.i.d. lijkt me het handigst. Wel zou ik dit toch in de toekomst proberen te veranderen. 2000 bestanden renamen in een loop, lijkt me geen bereklus.
Zoiets dus:
code:
1
2
3
4
5
6
| $arr=array("tif", "jpg", "jpeg");
foreach ($arr as $value)
{
if ( is_file( $filename.".".$value) )
echo "<img ....... blabla";
} |
[edit2]De glob functie die spider geeft, lijkt me veel geschikter trouwens. Kende ik nog niet.
Noork wijzigde dit bericht 24-07-2008 12:08 (67%)
Reg. datum: 26 september 2003
voorbeeld wat je kan doen op de linux shell.
"convert image001 image001.jpg"
Dan checked ImageMagick automatisch de huidige formaat en zet deze om naar een jpg.
Dat is het enigste wat ik me kan bedenken, alleen niet elke server heeft standaard ImageMagick
edit: lees nu het bericht door en zie dat dit niet echt hetgeen is voor de TS, wellicht kan hij hier evengoed iets mee. Ik dacht nml dat de extensie niet bekend was als in geen extentie
MrOizo2005 wijzigde dit bericht 24-07-2008 12:07 (22%)
Ja, met de hand wel. Echter, waarom geen scriptje dat loopt door de folder met images? En dan met de bovengenoemde functies: getimagesize en exif_imagetype bepalen wat het bestandstype is en deze vervolgens met een mooie update statement in de juiste rij te knallen? Ik neem aan dat je je bestandsnaam in de db hebt, dus het is een gevalletje UPDATE ... WHERE filename='$actieve_filename_uit_de_loop'quote:gizmo9003 schreef op donderdag 24 juli 2008 @ 11:57:
Echt een kloteklus om die 2000 records met de hand nog eens na te lopen.
Heb je al gekeken wat Spider.007 aandroeg?quote:Nee, ik wil dat php in de folder kijkt, of het bestand met een bepaalde naam bestaat. Maar php weet de extensie niet, dus die zal meerdere bestanden moeten proberen.
"The thing under my bed waiting to grab my ankle isn't real. I know that, and I also know that if I'm careful to keep my foot under the covers, it will never be able to grab my ankle." - Stephen King
Ten eerste zou ik wel voor een uitbreiding van de database pleiten. Dit betekent echter neit dat je alles handmatig bij langs moet. Als je nu een oplossing zou vinden voor het extensie probleem dan kun je die 2000 records toch ook gewoon automatisch aanpassen?
Voor het achterhalen van de extensie zou je natuurlijk ook gewoon de bestanden met een dir of ls command kunnen opvragen en dan wildcards gebruiken.
Ken Thompson's famous line from V6 UNIX is equaly applicable to this post:
'You are not expected to understand this'
De oplossing van Spider werkt inderdaad ook. Ik ben nog aan het overwegen of ik toch niet alle volledige filenames in de database zal zetten inderdaad. Probleem is dat de pasfoto's ieder jaar aangeleverd worden in een ander formaat. Ik beheer het ledenbestand dan ook niet meer, dus de vraag is maar of de nieuwe beheerder weet hoe hij de juiste extensies in de database krijgt.quote:Schonhose schreef op donderdag 24 juli 2008 @ 12:06:
[...]
Ja, met de hand wel. Echter, waarom geen scriptje dat loopt door de folder met images? En dan met de bovengenoemde functies: getimagesize en exif_imagetype bepalen wat het bestandstype is en deze vervolgens met een mooie update statement in de juiste rij te knallen? Ik neem aan dat je je bestandsnaam in de db hebt, dus het is een gevalletje UPDATE ... WHERE filename='$actieve_filename_uit_de_loop'
Heb je al gekeken wat Spider.007 aandroeg?
tjah..
Ligt er ook aan hoe je de update regelt. Upload je de pasfoto's stuk voor stuk? Dan is het toch niet zo lastig om de volledige bestandsnaam in de db te gooien.quote:gizmo9003 schreef op donderdag 24 juli 2008 @ 12:12:
[...]
De oplossing van Spider werkt inderdaad ook. Ik ben nog aan het overwegen of ik toch niet alle volledige filenames in de database zal zetten inderdaad. Probleem is dat de pasfoto's ieder jaar aangeleverd worden in een ander formaat. Ik beheer het ledenbestand dan ook niet meer, dus de vraag is maar of de nieuwe beheerder weet hoe de juiste extensies in de database krijgt.
Reg. datum: 22 januari 2004
Hoe kun je foto.jpg en foto.gif dan uit elkaar houden?quote:Janoz schreef op donderdag 24 juli 2008 @ 12:10:
Mensen, het gaat hier helemaal niet om het plaatje zelf, maar om de extensie. Om 1 of andere reden heeft de topicstarter alleen maar het deel van de filenaam zonder de extensie in zijn database staan, maar in de map staan de bestanden met extensie.
Whereas Europeans generally pronounce my name the right way ('Nick-louse Veert'), Americans invariably mangle it into 'Nickel's Worth.' This is to say that Europeans call me by name, but Americans call me by value - Niklaus Wirth
De pasfotos komen in 1 grote zip, die vervolgens wordt uitgepakt naar een directory. Ook is het mogelijk dat een persoon op een willekeurig tijdstip een nieuwe pasfoto opstuurt. Het handigste werkt het dan als het script elke extensie controleert.quote:Noork schreef op donderdag 24 juli 2008 @ 12:13:
[...]
Ligt er ook aan hoe je de update regelt. Upload je de pasfoto's stuk voor stuk? Dan is het toch niet zo lastig om de volledige bestandsnaam in de db te gooien.
Anders moet de nieuwe beheerder straks bij iedere nieuwe pasfoto ook een wijziging in de database doen.
tjah..
Controleer de eerste 3 a 4 tekens van de data. Gif begint bijv. met "GIF8".
Gegevens kun je hier opzoeken: http://filext.com/file-extension/gif
Manier 2:
Alle plaatjes openen met getimagesize().
http://nl3.php.net/manual/en/function.getimagesize.php
All your women are belong to me.
Nogmaals: het is dus niet iets eenmaligs!! Pasfotos (en dus extensies) kunnen door het jaar heen ook veranderen. De filename staat ook nergens in de database, maar deze matcht wel altijd een bepaald patroon, Achternaam,Voorletters(studentnr) en die losse gegevens staan wel in de database. Dus een eenmalige scan om alle juiste extensies in de database in te voegen is hier geen oplossing.quote:TheBorg schreef op donderdag 24 juli 2008 @ 12:22:
Manier 1:
Controleer de eerste 3 a 4 tekens van de data. Gif begint bijv. met "GIF8".
Gegevens kun je hier opzoeken: http://filext.com/file-extension/gif
Manier 2:
Alle plaatjes openen met getimagesize().
http://nl3.php.net/manual/en/function.getimagesize.php
Maar ik ben er inmiddels wel aan uit, het werkt nu voor de meest gebruikelijke extensies! Bedankt!
gizmo9003 wijzigde dit bericht 24-07-2008 12:25 (16%)
tjah..
Dan komen ze toch inclusief extensie? Of knip je die eraf met een scriptje? Hiernaast lijkt het me niet moeilijk om ze allemaal naar 1 formaat te converteren. Scheelt weer gedoe in je code.quote:gizmo9003 schreef op donderdag 24 juli 2008 @ 12:17:
[...]
De pasfotos komen in 1 grote zip, die vervolgens wordt uitgepakt naar een directory. Ook is het mogelijk dat een persoon op een willekeurig tijdstip een nieuwe pasfoto opstuurt. Het handigste werkt het dan als het script elke extensie controleert.
Anders moet de nieuwe beheerder straks bij iedere nieuwe pasfoto ook een wijziging in de database doen.
Ze komen met extensie ja.quote:Noork schreef op donderdag 24 juli 2008 @ 12:25:
[...]
Dan komen ze toch inclusief extensie? Of knip je die eraf met een scriptje? Hiernaast lijkt het me niet moeilijk om ze allemaal naar 1 formaat te converteren. Scheelt weer gedoe in je code.
Maar ik moet rekening houden met het "noob" gehalte van eventueel komende beheerders, die wellicht niet in staat zijn een tif bestand om te zetten naar jpg.
tjah..
* TeeDee heeft het idee dat je nu een oplossing voor een niet bestaand probleem aan het zoeken ben.
Sla de extensie op en je bent al aardig op weg
Of je bent teveel bezig met 'toekomstige' zaken. (hint).
Ik bedoel; noob gehalte van komende beheerders? Lijkt mij dat het juist makkelijk is om met een extensie te werken. Als een 'beheerder' (*) een noob is, wat let je om even het e.e.a. op te notuleren en dat door te geven.
* beheerder als in sysadmin? Zo ja, goeie sysadmin
Website TweakU2, met Bio! Heart..pumps blood.Has nothing to do with emotion! I'm Bored
Niet. Ik heb het systeem ook niet bedacht. Het is de realiteit in de situatie van de topicstarter.quote:Icelus schreef op donderdag 24 juli 2008 @ 12:17:
[...]
Hoe kun je foto.jpg en foto.gif dan uit elkaar houden?
Ken Thompson's famous line from V6 UNIX is equaly applicable to this post:
'You are not expected to understand this'
Als het zo noobproof moet zijn, waarom bestaat dan uberhaupt de mogelijkheid dat men handmatig op de server de foto's kan verwijderen/toevoegen etc?quote:gizmo9003 schreef op donderdag 24 juli 2008 @ 12:30:
[...]
Ze komen met extensie ja.
Maar ik moet rekening houden met het "noob" gehalte van eventueel komende beheerders, die wellicht niet in staat zijn een tif bestand om te zetten naar jpg.
Goede vraagquote:Hielko schreef op donderdag 24 juli 2008 @ 13:46:
[...]
Als het zo noobproof moet zijn, waarom bestaat dan uberhaupt de mogelijkheid dat men handmatig op de server de foto's kan verwijderen/toevoegen etc?
Maar het staat op een dataserver, die gewoon lokaal via \\blabla bereikbaar is. Daarin staat een map "algemeen/pasfotos" waar alle pasfoto's in gaan. Helemaal "buiten het bereik" van de webserver, om het zo maar te noemen. Dus dat is gewoon kopieren/plakken in de windows verkenner.
tjah..
Website TweakU2, met Bio! Heart..pumps blood.Has nothing to do with emotion! I'm Bored
Ben je niet gewoon sneller klaar als je een batch filetje schrijft wat die bestandjes convert met imagemagick en gelijk kopieert? Die batch file kun je dan gelijk schedulen op de fileserver zodat ie bijv. 1x per nacht draaitquote:gizmo9003 schreef op donderdag 24 juli 2008 @ 15:23:
[...]
Goede vraag
Maar het staat op een dataserver, die gewoon lokaal via \\blabla bereikbaar is. Daarin staat een map "algemeen/pasfotos" waar alle pasfoto's in gaan. Helemaal "buiten het bereik" van de webserver, om het zo maar te noemen. Dus dat is gewoon kopieren/plakken in de windows verkenner.
SchizoDuckie wijzigde dit bericht 24-07-2008 16:06 (15%)
Waarom zou je er niet iets eenmaligs van maken? (zoals in de post hierboven ook wordt gesuggereerd).quote:gizmo9003 schreef op donderdag 24 juli 2008 @ 12:24:
[...]
Nogmaals: het is dus niet iets eenmaligs!! Pasfotos (en dus extensies) kunnen door het jaar heen ook veranderen. De filename staat ook nergens in de database, maar deze matcht wel altijd een bepaald patroon, Achternaam,Voorletters(studentnr) en die losse gegevens staan wel in de database. Dus een eenmalige scan om alle juiste extensies in de database in te voegen is hier geen oplossing.
Maar ik ben er inmiddels wel aan uit, het werkt nu voor de meest gebruikelijke extensies! Bedankt!
Nu heb je een script gemaakt dat vanalles gaat afzoeken op voornaam, achternaam, studentnummer en een willekeurige extensie?
Als je nu eenmalig alles foto's goed zet en bijvoorbeeld allemaal op studentnummer opslaat op schijf, dan is het wel iets eenmaligs. Het enige wat je in je database dan nog zou kunnen opslaan is de extensie, of gebruik de glob functie (een van de eerste reacties in het topic).
Wanneer nieuwe pasfoto's geupload worden, sla je die onder het studentnummer op en je hebt er geen omkijken meer naar toch, of mis ik nu iets....
Tweak.to - Gratis URL Forwarding ~ System specs
*psst* Ketchup-units pwnen, curry is zooo 2002; je bent af! ~ RobIII is modje! \o/
Pagina: 1
